这是一道朗讯的笔试题(我把一些相关资料汇总了一下,希望大家能进来广泛的探讨,不甚感激!)
#include <stdio.h>
int main()
{
char ca;
unsigned char ucb;
unsigned short usc;
ca = 128;
ucb =128;
usc = ca + ucb;
printf("%d\n", usc);
usc = ca + (short)ucb;
printf("%d\n", usc);
usc = (unsigned char)ca + ucb;
printf("%d\n", usc);
usc = ca + (char)ucb;
printf("%d\n", usc);
getchar();
return EXIT_SUCCESS;
}
结果是:0, 0, 256, 65280.
这道题最难得部分,莫过于你是否理解c语言中的数据类型转换 。
有个名词“Inerger Promotion"(整型提升):在算术类型中有这么一种转换,有符号或无符号的char型,short型和Bit-field在做算术运算之前,首先要做整型提升,然后才能参与运算。(其它的一些类型之间的转换,可以参考任何一本c语言书)
一下是一些关键性概念:
无论要做什么运算都要先看这个数存入内存是什么样子的;
类型提升/截断的时候都是对内存中数据的操作,提升的时候就是需要 进行扩位:对无符号数扩位的时候直接把扩出的位上补零即可(因为unsigned都是正数);有符号
数进行扩位,则进行符号位扩展(sign extension)如果是正数即原最高位 是零则补零,如果是负数即原最高位是1则全补1;进行数据截断的时候是 从低位开始数位数然后截断,这里注意我们使用的一般都是小端机(little Endian)-----------http://blog.csdn.net/gukesdo/article/details/6909766
以下是一些参考博客和例题:
http://bbs.csdn.net/topics/380197359
http://www.cnblogs.com/qytan36/archive/2010/09/27/1836569.html
http://blog.csdn.net/zhenyongyuan123/article/details/5846764
http://bbs.csdn.net/topics/380079979
http://bbs.chinaunix.net/thread-1070673-1-1.html