关于文件字符读取中的get()函数的问题
c++语言中:while((c=fin.get())!=EOF)cout<<c;get()函数是一个一个字节读取的,为什么也能正确输出汉字(2字节的吧)?...
c++语言中:while((c=fin.get())!=EOF)
cout<<c;
get()函数是一个一个字节读取的,为什么也能正确输出汉字(2字节的吧)? 展开
cout<<c;
get()函数是一个一个字节读取的,为什么也能正确输出汉字(2字节的吧)? 展开
展开全部
cout<<p<<endl;就不会输出汉字。
原因:仔细观察ASCII字符表,从第161个字符开始,后面的字符并不经常为用户所使用,负值也未使用。GB2312编码方式充分利用这一特性,将161-255(-95~-1)之间的数值空间作为汉字的标识码。既然255-161 = 94不能满足汉字容量的要求,就将每两个字符并在一块(即一个汉字占两个字节),显然,94* 94 =8836基本上已经满足了常用汉字个数的要求。计算机处理字符时,当连续处理到两个大与160(或-95~-1)的字节时,就认为这两个字节存放了一个汉字字符。
原因:仔细观察ASCII字符表,从第161个字符开始,后面的字符并不经常为用户所使用,负值也未使用。GB2312编码方式充分利用这一特性,将161-255(-95~-1)之间的数值空间作为汉字的标识码。既然255-161 = 94不能满足汉字容量的要求,就将每两个字符并在一块(即一个汉字占两个字节),显然,94* 94 =8836基本上已经满足了常用汉字个数的要求。计算机处理字符时,当连续处理到两个大与160(或-95~-1)的字节时,就认为这两个字节存放了一个汉字字符。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询