c语言编译运行乱码是什么原因?

c语言编译运行乱码是什么原因?,第1张

这种情况多数是由于 *** 作系统的语言选项不正确引起的。建议你查看一下控制面板中的区域和语言选项,特别是有关“非Unicode程序的语言”,一定要选择成“中文(简体,中国)”。然后重启电脑。

数字当然是乱的了

因为写入的是二进制数据

比如字符a的ascii编码为97那么你存储在文件里的是97

打开时二进制数据97就是a的ascii编码所以显示为a

如果你写入的是数字1,1在ascii上没有对应的可显示字符

自然就无法进行显示了

而你想要显示的数字类似1其ascii值为49,所以你看到的文件是显示的1其二进制存储的数据其实是49

提几个建议。1)没给出str的大小,不知道你定义的多大。至少str要保证120以上。考虑用2的倍数最优可以charstr[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。另外文件最好用宽字符的。就可以避免乱码了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11878111.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存