1.
signed char a=0xe0;
unsigned int b=a;
unsigned char c=a;
下面说法正确的是:
A (a>0 )&&(b>0)为真 B c==a 为真 C b的16进制为0xffffffe0 D 都不对
在计算机中数字都是用补码表示的,所以有符号数的最高位为符号位,余下的才是表示数字的大小,所以A选项中b>0是错的;
选项的B中a解释为小于0的数,b解释为大于的数,肯定不相等;
选项C char转换成int会先拓宽char然后才赋值给int,其中有符号数拓宽填充符号位,无符号数填充0;
2.
int main()
{
long long a=1;
long long b=2;
long long c=3;
printf("%d,%d,%d",a,b ,c);
return 0;
}
输出结果是什么?(32位环境,cpu为小端模式,所有参数用栈传递)
无论在32/64环境中long long都是8个字节,参数从右到左进栈,栈中从栈底到栈顶依次为c、b、a,%d将打印栈中的4个字节,又因为是小端模式,所以打印结果为1 0 2
3.
unsigned int a= 0x1234;
unsigned char b=*(unsigned char *)&a;
在32位大端模式处理器上变量b= ?
大端存储,从低地址到高地址存储的为0x34、0x12,b指针指向a的第一个字节即0x34,0x34转换为ascii为0,所以输出结果为0.