默认情况下的char是signed char。
unsigned char表示数字范围是0-255,signed char表示数字范围是-128-127。对于表示负数的下限为什么是-128,而不是直观的-127,原因是涉及到了补码。
例如,-128其实在计算机内部的存储为10000000,对10000000进行转换,首先减去1,变为:01111111,再对各位取反,变为:10000000,即128。
这部分内容可以参考:http://blog.youkuaiyun.com/steven030143/article/details/5917657
那么unsigned char和char究竟有什么应用的区别呢?
当 char或者unsigned char与int 类型进行转换时,会有区别,其它时候都没有区别。
可以直接给char赋数字,例如char a = 65,a其实就是表示字符A,又如char a =67,a其实就是字符C。
可以在char和Int 之间进行转换,int i=a;由于char表示的数字范围是-128-127,所以要进行转换时,赋值时尽量不要超过这个范围。
unsigned char表示的数字的范围是0-255,赋值时也要在这个范围里。超出了范围,结果就意想不到了,需要一个个位去比对了。
参考:【1】http://blog.youkuaiyun.com/steven030143/article/details/5917657
【2】http://www.cnblogs.com/qytan36/archive/2010/09/27/1836569.html
本文详细解释了在计算机编程中,默认情况下char被设置为signedchar的原因,以及unsignedchar与char之间的区别与应用。重点阐述了两者表示数字范围的不同,如何在两者间进行转换,并提供了实际操作示例。
832

被折叠的 条评论
为什么被折叠?



