为啥C语言输出文件内容乱码
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥C语言输出文件内容乱码相关的知识,希望对你有一定的参考价值。
如图,找书上的例子修改按自己的要求修改了一下用不了,哪里出问题了?
这种文本文件,不能直接使用读到结构的方法。因为结构里会有非文本的控制符,比如字符串结束符'\0'。一般使用直接读到结构的方法,只限于二进制格式的文件,并且最好是读自己创建的文件,别人创建的,格式刚刚好合适创建结构的也很少。
你这个乱码,你的文件里,学号长度为10个字节,所以你定义学号这个变量时,必须定义11个字节的长度,因为字符串的变量,必须要有一个'\0'作为结束,不然的话,显示的时候,没有结束符就会接着往下显示,就会有乱码出现。
如果仅仅是这三行的话,倒也能使用结构来读,比如结构里定义num[11],读完后执行一下num[10] = '\0';给它补一个结束符。但如果有人叫“王老四”,名字有的是2个字,有的是3个字这样,你这个就不好判断了。
这种文本,最好是使用fscanf("%s %s %s %s %s", num, name, sex, date, major)的形式来读取。每次读取一行。(注意字符串定义变量时,长度一定要多加1位)。追问
想输出的时候不用for循环,就是想可以在while里面输入了就输出,求指导
。。现在是这样的
可以说清楚些吗。。。。
为啥MyEclipse的Console输出中文为乱码?
主要原因是默认的中文读取方式是iso8859-1或者GBK的,而项目大部分是UTF-8的,这样就会出现乱码。可以直接转码下即可:
String s = new String(字符串.getBytes("iso8859-1"),"UTF-8"); 参考技术A
打开运行-配置
在VM arguments中添加-Dfile.encoding=GB2312
在Console encoding中选择GB2312
以上是关于为啥C语言输出文件内容乱码的主要内容,如果未能解决你的问题,请参考以下文章