C语言输出中文乱码

Python015

C语言输出中文乱码,第1张

提几个建议。1)没给出str的大小,不知道你定义的多大。至少str要保证120以上。考虑用2的倍数最优可以char

str[122]并且因为系统将自动在最后加'\0'。最好设定读取121为好。以免读取半个中文字。2)fgets的用法问题。

追加返回值的判断为好。if(fgets(str,120,fp)!=null){

printf("%s\n",str)}3)关于出现乱码的问题,估计你的文件中有中文汉字。读取到119位的时候正好是某个汉字的前一半。要解决这个if(fgets(str,121,fp)!=null)

这里120

改成读偶数个121。另外文件最好用宽字符的。就可以避免乱码了。

C语言中一个汉字是由两个字节来表示的

而C语言编程主要是以字节为单位来显示

所以你的C语言输出中,如果汉字显示只显示了一个字节,就会有乱码出现了

正常的做法是,你的printf输出时,符号的长度要为偶数字节。

有几个小问题:

第一:c语言一般不支持中文,如果你用vc6.0++就是无法打印中文,一定会乱码,建议用英文;

第二:如果你用的c语言编译器支持中文,如devc++,则可以使用中文;

第三:我们的使用的字符格式,最多的是UTF-8,把默认代码页格式改为UTF-8试试吧

希望我的分享对你有用,感谢采纳