日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

C 语言读写中文出现乱码

發布時間:2025/4/5 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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 语言读写中文出现乱码的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。