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