C+ +中char、unsigned char和signed char是三种类型,因此在函数重载和模板偏特化时,应注意重写它们的三个版本。虽然它们是三种类型,但char不是unsigned char就是signed char,且char是否有符号可由编译器改变。因此不因编写依赖char是有符号还是无符号的代码。
在C/C++语言中,char变量为一个字节,8位,
signed char表示的范围:-128~127【-128在内存中的二进制表示为1000 0000,127在内存中的表示为0111 1111】;
unsign char表示的范围:0000 0000~1111 1111,即0~255注意:整数在内存中是以补码存取的,正数的补码:等于自己,负数的补码:取反加1,例如:127在内存中表示为0111 1111, -127在内存中表示为~(0111 1111)+1=1000 0001; 假定某内存单元p的内容是1111 1111,那么它一定是255吗?实际上取决于你的代码是要把它看成有符号还是无符号数,如果是无符号则表示255,如果是有符号则表示-1【对于有符号数,最高位为符号位,1表示负,0表示正】:
signed char c=*p; //c=-1
unsigned char c=*p;//c=255
这也解释了上面这段代码能判断编译器默认char类型
在 char 、unsigned char、signed char三者相互转换中,并不丢失数据
在实际工作中,char的用途还是很大的。以下将工作中遇到的问题记录。
1.unsigned char m_ucStr[] = {0x31,0x32}; 当char里面是16进制时,内存里面值是一样的。
1.1 若想实现内存里的数据是3132里
unsigned char *str = new unsigned char[sizeof(
m_ucStr)];
CopyMemory(str,array,sizeof(
m_ucStr));
2.unsigned char m_ucStr[] = {31,32}; 当char里面是10进制时,内存10进制转为16进制
3.在进制 char * 和 char *字符串复制时,若不指定源字符串长度,用 strcpy,若指定源字符串长度,用strncpy.但当源字符内存有 0x00时,则再也不能用 strcpy和strncpy了,只能用 memcpy.因为memcpy不以0x00为指定结束符