C語言補漏(1)--- char到int賦值的一個陷阱


作為一個C的新手(雖然學的第一門語言就是C,可是用C實際開發項目卻是最近的事情),對使用C過程中遇到的各類問題、疑惑、知識漏洞進行彌補無疑是非常有必要的,於是決定將每次遇到的知識漏洞寫到博客上。

今天在寫代碼的過程中對一個函數進行了重構,函數的用處是將一塊內存中的內容打印成16進制表示的字符串;很悲哀的輸入的是一個char指針:char* buffer;當調用Format("%02X",*buffer)的時候出現問題了,

比如:0xB0輸出變成了:“FFFFFFB0”;最后發現是char惹得禍;

char取為unsigned char還是signed char是平台相關的,而我的平台中,char默認為有符號的,那么(signed)char和unsigned char究竟有什么區別呢?

char帶符號能表示-128~127, unsigned char沒有符號位,能表示0~255;而本質上都是表示8位的數字。

但是我們如果要表示byte時(C本身沒有byte類型),應該用unsigned char,這是為什么呢?

因為當用char對int進行賦值時,系統認為最高位是符號位,而int可能是16或者32位,那么會對最高位進行擴展(注意,賦給unsigned int也會擴展)

而如果是unsigned char,那么不會擴展。

這就是二者的最大區別。

同理可以推導到其它的類型,比如short, unsigned short。等等

還是用例子來說明問題吧:

#include "stdafx.h"
#include <stdio.h>

void test(unsigned char v)
{
char c = v;
unsigned char uc = v;
unsigned int a = c, b = uc;
int i = c, j = uc;
printf("----------------\n");
printf("%%c: %c, %c\n", c, uc);
printf("%%X: %X, %X\n", c, uc);
printf("%%u: %u, %u\n", a, b);
printf("%%d: %d, %d\n", i, j);
}

int main(int argc, char* argv[])
{
test(0xB0);
test(0x68);
return 0;
}

運行結果:


所以,如果表示的是byte的情況,建議用unsigned char;當然,如果非要用char也可以;加上& 0xFF也能解決問題吧。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM