C 语言读写中文出现乱码
生活随笔
收集整理的這篇文章主要介紹了
C 语言读写中文出现乱码
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
使用 fopen 打開一個utf-8的txt文件,然后用fscanf讀取字符串,輸出發現是亂碼,顯示的是用ANSI編碼的對應字符
并且在寫入文件時,新產生的文件也是ANSI編碼的
一開始懷疑文件編碼是fopen函數決定的,所以在打開方式后加上了css=utf-8,但是這樣子反而導致文件無法打開了。
后來我懷疑文件編碼不是fopen決定的,于是我注釋掉了fwrite函數,然后驚訝地發現創建的txt是utf-8編碼的
因此我認為,讀取UTF8文件卻得到ANSI編碼的字符串是fscanf fwrite這些函數導致的,那么要如何正確的讀取中文呢?
這個問題一直困擾了我很久,我試著把文件輸出函數換成fputs。。
結果!!!他輸出成功了!!!!!
但是讀取之后在文本窗口輸出時,還是ANSI編碼,
至于這些函數的數據編碼方式之類的原理,我一直找了好久也沒找到
如果有大佬明白原因的話,希望可以不吝賜教
5.13
目前看到的解決方法有
1.采用w_char 寬字符來存儲,然后進行一些轉碼等操作
2.用二進制方式讀寫文件,用一個無符號字符unsigned char的長度8位為處理單元,最多有256種組合,對應256類字符(貼吧上看到的)
總結
以上是生活随笔為你收集整理的C 语言读写中文出现乱码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 宇宙星座信用卡怎么激活
- 下一篇: C语言 *n++和(*n)++的区别