腾讯几道题

本文分享了三道来自腾讯的编程题目,涉及整型比较、内存对齐与栈操作、大端模式处理器上的数据存储。解析了每道题目的答案,并详细解释了背后的原理,如数据类型转换、内存解释与存储模式等。
摘要由CSDN通过智能技术生成

转载来自: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 plain copy
  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 plain copy
  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 plain copy
  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.  


注:
大端模式:字数据的高字节存储在低地址中,而低字节存储在高地址中。
小端模式:字数据的高字节存储在高地址中,而低字节存储在低地址中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值