Fw: [問題] ptt編譯移植問題

看板PttCurrent作者 (.)時間9年前 (2014/08/06 21:40), 9年前編輯推噓0(000)
留言0則, 0人參與, 最新討論串1/1
※ [本文轉錄自 C_and_CPP 看板 #1JuQBV_3 ] 作者: erspicu (.) 看板: C_and_CPP 標題: [問題] ptt編譯移植問題 時間: Wed Aug 6 11:36:59 2014 開發平台(Platform): (Ex: VC++, GCC, Linux, ...) ARM Linux GCC 問題(Question): X86平台上 註冊時候輸入正確中文姓名 PTT給過 但ARM平台上 住測時候輸入正確中文姓名 PTT顯示 "您的輸入似乎不正確" 無法繼續後續註冊程序 錯誤結果(Wrong Output): 姓名正確性判別失誤 程式碼(Code):(請善用置底文網頁, 記得排版) http://ideone.com/L6Dw9G 補充說明(Supplement): PttCurrent版太冷僻 沒人會回 自自己嘗試解決 只好定義FOREIGN_REG flag 直接忽略中文姓名正確判別 才能繼續後續註冊 編譯過程中 的警告訊息 查起來是 assembler的問題 但我現在沒辦法貼上 目前猜測是 arm上 編譯器或是組譯器問題 可能跟arm.x86一些cpu架構性差異問題 (LE BE?) 這問題有空自己會繼續追 但想說有經驗的人或許會知道怎麼回事 滿奇妙的 中間應該有不少文章 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 60.248.56.181 ※ 文章網址: http://www.ptt.cc/bbs/C_and_CPP/M.1407296223.A.FC3.html

08/06 11:43, , 1F
有沒可能是 utf8/big5 中文的問題
08/06 11:43, 1F
check 環境語系問題 應該不是 這問題追起來應該相當多文章 ※ 編輯: erspicu (60.248.56.181), 08/06/2014 11:50:37

08/06 12:19, , 2F
如果直接給 Big 5 編碼過後的 char sequence 呢?
08/06 12:19, 2F
真的很奇妙 大概發現原因 http://ideone.com/OuBhdX char test_char2[]= "中文字測試" ; 網站經過處理變亂碼 但原始是這樣 經過測試這code儲存為ASII編碼 然後在不同的環境用不同的編譯器去跑 印出來的數值會不太相同 WIN7 CODEBLOCKS GCC跑出來是 char test! 98 , 97 , 120 , 101 -92 , -92 , -92 , -27 x86 linux上是 char test! 98 , 97 , 101 , 114 -92 , -92 , -27 , -90 arm linux上是 98 , 97 ,120 , 101 164 , 164 ,164 , 229 ※ 編輯: erspicu (60.248.56.181), 08/06/2014 17:38:55

08/06 17:59, , 3F
Windows 7 和 ARM Linux 其實是一樣的, 只是 char 定義為
08/06 17:59, 3F

08/06 17:59, , 4F
signed 或 unsigned 的差異; 怎麼看都還是編碼問題啊
08/06 17:59, 4F
http://blog.cdleary.com/2012/11/arm-chars-are-unsigned-by-default/ 這應該就是問題原因了 比較奇怪的是同是X86 列印英文 一組是98 , 97 , 120 , 101 一組是98 , 97 , 101 , 114 ※ 編輯: erspicu (60.248.56.181), 08/06/2014 18:15:47

08/06 18:14, , 5F
就 sign extension 超過 0x7F 的被一直補 1 出來就變負數
08/06 18:14, 5F

08/06 18:15, , 6F
然後 linux 會把你的中文用 UTF-8 存,Win 用 Big5 存
08/06 18:15, 6F

08/06 18:16, , 7F
至於 linux 的 98 97 "101" 應該是你打字錯誤
08/06 18:16, 7F
X86 LINUX sample 有打錯 array index變成 0,1,3,4 ..... 所以的確只是signed和unsigned的問題 沒錯 這麼說來按照PTT sources的寫法 要編譯正確運作 在arm上就要多下一點編譯器參數了 ※ 編輯: erspicu (60.248.56.181), 08/06/2014 18:20:58

08/06 18:23, , 8F
這個故事告訴我們請不要對 non-ASCII input 用 char...
08/06 18:23, 8F

08/06 18:24, , 9F
不知道如果提 patch 改成 signed char 他們會不會收
08/06 18:24, 9F
※ 編輯: erspicu (60.248.56.181), 08/06/2014 18:25:11

08/06 21:40, , 10F
借轉
08/06 21:40, 10F
※ 發信站: 批踢踢實業坊(ptt.cc) ※ 轉錄者: erspicu (61.70.105.149), 08/06/2014 21:40:36
文章代碼(AID): #1JuZ1MJ- (PttCurrent)