腾讯几道题

来源:互联网 发布:软件企业收入 编辑:程序博客网 时间:2024/05/21 10:07

转载来自:http://bbs.csdn.net/topics/390424969

第一题:

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 都不对

[cpp] view plaincopy
  1. // 答案:C  
  2. // 整形比较小于int的会扩宽的int再比较, 而有符号数扩宽填充符号位, 无符号数填充0, 导致扩宽后两个整形的二进制不再相等, 选择C.  

第二题:
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为小端模式,所有参数用栈传递)

[cpp] view plaincopy
  1. // 答案:1 0 2   
  2. // 1)无论32/64, long long都是8字节整形, %d会将参数栈上的内存解释为4字节int, 所以会造成打印结果异常.  
  3. // 2)由于任何多字节变量都要做内存对齐, 原则是自身长度与sizeof(int)间较小值, 所以3个long long在栈上是可以紧密排列的, 并且第一个long long对齐在sizeof(int)对// 齐内存地址.  
  4. // 3)栈地址向低增长, 函数参数入栈从右向左, 所以第一个long long是参数栈上最低地址的参数, 总共只需要1.5个long long就足以打印完3个%d.   
  5. // 4)小端情况下, 第一个%d解释了第一个long long的低4字节, 打印1. 第二个%d解释了第一个long long的高4字节, 打印0. 第三个%d解释了第二个long long的低4字节, 打印2.  

第三题:
unsigned int a= 0x1234;
unsigned char b=*(unsigned char *)&a;
在32位大端模式处理器上变量b= ?

[cpp] view plaincopy
  1. //  答案:0  
  2. //  unsigned int a= 0x1234; 其中int是4字节, 补齐16进制表示为: 0x00 00 12 34  
  3. //  unsigned char b=*(unsigned char *)&a; 由于大端存储, 所以上述int a变量的最低地址存储的是   
  4. //  十六进制表示中最左边的1字节, 为0x00.  


注:
大端模式:字数据的高字节存储在低地址中,而低字节存储在高地址中。
小端模式:字数据的高字节存储在高地址中,而低字节存储在低地址中。