其实BYTE就是
unsigned char,
本质上BYTE和char两种类型都占一个字节。
作为字符使用时,都是存储字符的ASCII码。比如: unsigned char uc='a'; char c='a'; printf("%d %d",uc,c); 结果为: a a 作为整数使用时,两种类型的取值范围就不同了。unsigned char 可取0至255,而char可取-128至+127。比如: unsigned char uc=255; char c=255; printf("%d %d",uc,c); 结果为: 255 -1 原因是没有用unsigned修饰的char类型系统将其存储的一个字节值(8位2进制)看作为一个有符号数来处理,最高位为0时,表示正数,为1时表示负数,表示负数时的值为余下7位二进制每一位取反后整体+1。 比如上例中:char c=255; 表面看来超过了char的范围,但系统并不是这样处理的。 系统将十进制数255转为二进制数11111111进行存储。在计算或打印时,发现最高位为1,是负数,余下7位1111111取反后为0000000,加1后为0000001,转为十进制数等于1,最后系统当作-1看待。所以此时按整数打印c时,输出为-1。 总的来说,系统最终存储的都是二进制数11111111,只是在参与运算或显示的时候,unsigned char和char才会有所区别。