C+ +中char、unsigned char和signed char是三種類型,因此在函數(shù)重載和模板偏特化時,應注意重寫它們的三個版本。雖然它們是三種類型,但char不是unsigned char就是signed char,且char是否有符號可由編譯器改變。因此不因編寫依賴char是有符號還是無符號的代碼。
在C/C++語言中,char變量為一個字節(jié),8位,
signed char表示的范圍:-128~127【-128在內存中的二進制表示為1000 0000,127在內存中的表示為0111 1111】;
unsign char表示的范圍:0000 0000~1111 1111,即0~255注意:整數(shù)在內存中是以補碼存取的,正數(shù)的補碼:等于自己,負數(shù)的補碼:取反加1,例如:127在內存中表示為0111 1111, -127在內存中表示為~(0111 1111)+1=1000 0001; 假定某內存單元p的內容是1111 1111,那么它一定是255嗎?實際上取決于你的代碼是要把它看成有符號還是無符號數(shù),如果是無符號則表示255,如果是有符號則表示-1【對于有符號數(shù),最高位為符號位,1表示負,0表示正】:
signed char c=*p; //c=-1
unsigned char c=*p;//c=255
這也解釋了上面這段代碼能判斷編譯器默認char類型
在 char 、unsigned char、signed char三者相互轉換中,并不丟失數(shù)據
在實際工作中,char的用途還是很大的。以下將工作中遇到的問題記錄。
1.unsigned char m_ucStr[] = {0x31,0x32}; 當char里面是16進制時,內存里面值是一樣的。

1.1 若想實現(xiàn)內存里的數(shù)據是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為指定結束符