2、 32 位机上根据下面的代码,问哪些说法是正确的?
signed char a = 0xe0;
unsigned int b = a;
unsigned char c = a;
A. a>0 && c>0 为真 B. a == c 为真 C. b 的十六进制表示是:0xffffffe0 D. 上面都不对
A:
分析 a>0, 首先进类型提升,将signed char 提升为signed int,值为0xffffffe0,是负数,所以a>0错误。分析c>0,首先进类型提升,将unsigned char 提升为signed int,值为0x000000e0,是正数,所以c>0正确
B:
经过A的分析,可知B错误
C:
首先对a进行类型提升,将signed char 提升为signed int,值为0xffffffe0,然后将其赋值给unsigned int b,所以C正确
3、 int a[10]; 问下面哪些不可以表示 a[1] 的地址?
A. a+sizeof(int) B. &a[0]+1 C. (int*)&a+1 D. (int*)((char*)&a+sizeof(int))
A:
数组名a相当于一个整型指针,只是相当于而已,两者之间不能划等号。这里把a看做一个整型指针int *p,它指向数组的第一个元素,a+4则指向了a[4]
B:可以表示a[1]
C:
(int*)&a +1; &a是指向数组的指针,即 int (*p)[10],那么&a+1,表示的a是a[9]之后的地址;(int *)&a则又变成了指向一个整型的指针,即指向了a[0]
D:参考C的分析