char类型
栈空间,遇到-1结束循环。
int类型则遇到-1不会结束循环。
4个字节的int。
每个汉字由两个负数组成。
映射过去后,-68变成了:256-68=188。
int类型读过去变成了正数。
读到-1,不过是255,0xFF。
0xFF是8个1,不会退出循环,32个1,全是FF才退出循环。
char类型才是8个1,就结束读取循环。
汉字的编码问题:
汉字的ASC值为什么会是负数 - 程序人生,学海无涯 - CSDN博客 https://blog.csdn.net/qincode/article/details/9390939
汉字存放在计算机中,称为:机内码。
它和ASCII码,是有根本区别的。
ASCII码是用来存放阿拉伯数字、英文、符号等等,和汉字,没有一丁点关系。
“中”的机内码是 D6D0。
D6D0,当成有符号数,写成十进制数字就是-10544;
D6D0,当成无符号数,写成十进制数字就是 54992。
英文标准的ASCII码中只有128个符号,只需要7位,但是计算机分配存储的最基本单位是字节,至少是8位,因此最高位为0;
因此常见的西文符号的ASCII都是在0-127之间,无论是有符号还是无符号去观察它们,都是正的。
中文的符号远超过256个,因此用一个字节不能存储汉字,早期的GB2312采用了两个字节。
但是很麻烦的问题是一个汉字用两个字节存储在计算机中后,和两个西文字母的ASCII混淆,为了避免这个混淆,汉字两个字节的最高位都是1。
如果用有符号的数去读取一个汉字的内容,最高位的1正好和负号位置相同,因此此时就会发现汉字的内吗是负的。
汉字的ascii码怎么是负数?_百度知道 https://zhidao.baidu.com/question/342798633.html