|
作為一個C的新手(雖然學的第一門語言就是C,可是用C實際開發(fā)項目卻是最近的事情),對使用C過程中遇到的各類問題、疑惑、知識漏洞進行彌補無疑是非常有必要的,于是決定將每次遇到的知識漏洞寫到博客上。 今天在寫代碼的過程中對一個函數進行了重構,函數的用處是將一塊內存中的內容打印成16進制表示的字符串;很悲哀的輸入的是一個char指針:char* buffer;當調用Format("%02X",*buffer)的時候出現問題了, 比如:0xB0輸出變成了:“FFFFFFB0”;最后發(fā)現是char惹得禍; char取為unsigned char還是signed char是平臺相關的,而我的平臺中,char默認為有符號的,那么(signed)char和unsigned char究竟有什么區(qū)別呢? char帶符號能表示-128~127, unsigned char沒有符號位,能表示0~255;而本質上都是表示8位的數字。 但是我們如果要表示byte時(C本身沒有byte類型),應該用unsigned char,這是為什么呢? 因為當用char對int進行賦值時,系統(tǒng)認為最高位是符號位,而int可能是16或者32位,那么會對最高位進行擴展(注意,賦給unsigned int也會擴展) 而如果是unsigned char,那么不會擴展。 這就是二者的最大區(qū)別。 同理可以推導到其它的類型,比如short, unsigned short。等等 還是用例子來說明問題吧: #include "stdafx.h" 運行結果:
所以,如果表示的是byte的情況,建議用unsigned char;當然,如果非要用char也可以;加上& 0xFF也能解決問題吧。 |
|
|