char、unsigned char與字面值比較的相關問題
最近做一個專案,定義了一個char陣列,裡面存放別人傳送過來的訊息。定義的訊息頭是0xff0xff,所以我收到訊息後就與0xff進行比較,結果卻發現不相等。看了一些資料,發現還是自己對基礎知識的掌握不到位。
首先,我寫了個測試程式,程式碼及執行結果如下:
void test_num() { char a = 0x01; char b = 0xfe; unsigned char c = 0xfe; printf("a=%02x\n",a); printf("b=%02x\n",b); printf("c=%02x\n",c); printf("fe=%02x\n",0xfe); printf("(char)fe=%02x\n",(char)0xfe); printf("-1=%02x\n",-1); if( a == 0x01) cout<<"a == 0x01"<<endl; if( b == 0xfe) cout<<"b == 0xfe"<<endl; if( b == (char)0xfe) cout<<"b == (char)0xfe"<<endl; if( c == 0xfe) cout<<"c == 0xfe"<<endl; if( 255 == 0xff) cout<<"255 == 0xff"<<endl; if( -1 == 0xff) cout<<"-1 == 0xff"<<endl; if( -1 == 0xffffffff) cout<<"-1 == 0xffffffff"<<endl; }
執行結果如下:
分析:print 02x列印的是int值,現在我們傳遞的都是char型別,所以首先就存在著型別轉換。char是8位的,大部分系統下int是32位的,所以首先需要補24位的資料。那資料應該補什麼呢,實際上是看這個變數的正負情況的,正數則補0,負數補1.這個具體可以參考
https://blog.csdn.net/qq_39165336/article/details/78383239,此文對此進行了詳細的測試。
後面進行的==判斷,一邊是char型別,一邊是字面值常量。那這個字面值常量是什麼型別呢?經查詢相關文件得知字面值常量是int、unsigned int、long、unsigned long、long long、unsigned long long的較小值。所以前面幾個都是char和int進行比較,這就涉及到剛剛說過的型別轉換。最後一個字面值常量是unsigned int,所以需要將char轉換為unsigned int,在擴充套件符號位之後將其理解為一個正數,實際上也就是取模。最終顯示他們是相等。
最後說一句,如果我們是想存一個字串,可以定義一個char陣列,如果只是想開闢一個記憶體儲存一些二進位制資料,最好定義為unsigned char。