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