C_and_CPP 板


LINE

開發平台(Platform): (Ex: Win10, Linux, ...) Win10 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) NetBeans + Linux 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...) cJson (https://github.com/DaveGamble/cJSON) 問題(Question): 如果json的資料是 { "str": "4761739001010135", } 讀取後,將字串轉成數字,使用cJSON_AddNumberToObject後 如預期的得到 { "num": 4761739001010135 } 但是遇到尾數是零時,相同的程式碼就會變成科學符號 例如,如果json的資料是 { "str": "4761739001010010" } 結果得到 (非預期) { "num": 4.76173900101001e+15 } 相關程式碼如下: cJSON *pjNode = NULL; pjNode = cJSON_GetObjectItem(pInJson, "str"); if (pjNode != NULL) { cJSON_AddNumberToObject(pOutJson, "num", atoll(pjNode->valuestring)); } 感覺是大數字才會發生問題,因此想請教一下 1. 為何相同的程式碼,當尾數是0時,會變成科學符號呢? 2. 如何避免/修改成一般的數字,而不是科學符號呢? 麻煩了 感謝 餵入的資料(Input): 預期的正確結果(Expected Output): 錯誤結果(Wrong Output): 程式碼(Code):(請善用置底文網頁, 記得排版,禁止使用圖檔) 補充說明(Supplement): --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 60.250.189.43 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1659432682.A.B48.html ※ 編輯: renmax (60.250.189.43 臺灣), 08/02/2022 17:32:03
2F:→ renmax: C大 我是使用cJSON_AddNumberToObject後 去print json內容 08/03 16:30
3F:→ renmax: 發現 原本print出來的應該是長整數 但卻顯示科學符號 08/03 16:31
4F:→ renmax: 而科學符號 並不是我想要的結果 我希望print出來後 是整數 08/03 16:32
5F:→ renmax: 型態 您給的參考網址是取值 而不是塞值 謝謝幫忙>"< 08/03 16:33
6F:推 yvb: cJSON.c 找 Try 15 decimal 看那邊. %1.15g 和 %1.17g 的差別 08/03 16:57
7F:→ yvb: 這實作似乎不符合 RFC 8259 第六節 Numbers 的最後一段. 08/03 17:12
8F:→ yvb: 可能只參照到 RFC 4627. 08/03 17:18
9F:→ Chikei: 人家就說cJSON不支援long long,跟取值還是塞值沒關係。 08/04 13:44
10F:→ renmax: 不好意思 如果不支援long long的話 請問一下 08/04 14:15
11F:→ renmax: 1. 上方的例子中 為何只有尾數是零 才會變成科學符號呢? 08/04 14:16
12F:→ renmax: 2. 有什麼方法 可以做到預期的結果呢?(整數長度MAX = 20) 08/04 14:19
13F:→ renmax: 感謝y大和C大幫忙 08/04 14:20
14F:→ Chikei: 1. 上面yvb已經回答了 2. 沒有,請看完上面的issue回答 08/04 15:44
15F:→ Richun: 51 bits換算是15.3位,長度20已經超過了,cJSON不能用。 08/05 04:43
16F:→ Richun: 只能找其他的或是fork cJSON自己修 08/05 04:47
17F:推 LPH66: 長度 20 也不能用 double 或 int64_t 來存 08/05 20:30
18F:→ LPH66: uint64_t 只能擦邊 (18446744073709551615 正好 20 位) 08/05 20:31
19F:→ LPH66: 所以任意 20 位的數字可能要建議當字串來用 08/05 20:31
20F:→ renmax: 感謝各位大大的解釋 我仍然不太懂y大說的Try 15 decimal這 08/08 15:26
21F:→ renmax: 邊的意思 為何特定使用15和17 decimal來做判斷呢? 08/08 15:27
22F:推 LPH66: double 的精確度是 53 bit, 數學轉換對應十進位約 15.95 位 08/09 03:16
23F:→ LPH66: 所以一般可能會認為印出 1+15 位數就能足夠表示一個 double 08/09 03:16
24F:→ LPH66: 但實際上如果要達成所謂的 round-trip (轉成字串再轉回來時 08/09 03:17
25F:→ LPH66: 要得到完全一樣的 double 數值) 會需要印出 1+17 位 08/09 03:17
26F:→ LPH66: 才能使某些邊界狀況能夠得到分辨 08/09 03:17







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BuyTogether站內搜尋

TOP