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的分析