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也能解決問題吧。
轉載于:https://www.cnblogs.com/xiekeli/archive/2012/02/10/2345649.html
總結
以上是生活随笔為你收集整理的C语言补漏(1)--- char到int赋值的一个陷阱的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使Struts2与Servlet并存解决
- 下一篇: otdr全部曲线图带解说_副业推荐:电影