好文摘抄 [C语言]关于指针和int型的一道题目

看到一篇博客里的关于C语言指针的一道问题讨论,还提到了C99标准,我喜欢这种深层的细节讨论,特摘抄分享一下,或许以后可以给出自己的理解和解答。【来源是 http://www.cnblogs.com/aoaoblogs/archive/2010/10/16/1853313.html】

题目就下面几行,问printf的输出是什么?

1
2
3
4
5
6
7
int  main()
{
     unsigned int  a[3] = {0x010203, 0x040506, 0x070809};
     unsigned int  *b0 = (unsigned int *)( ( int )a + 1);
     printf ( "%x\n" , *b0);
     return  0;
}

在某个论坛上看到这个问题,展开讨论以后,其涉及到了不少的C语言知识。各位先不妨自己想想你自己的答案是什么。

 

--------------------------------------------------------分割线-------------------------------------------

 

在VS2008下,输出是6000102。原因如下:
a[3]数组在内存中的存储方式如下
低地址-------------------------------->高地址
03 02 01 00 06 05 04 00 09 08 07 00
     ^^^^^^^^
     b0指向这里
所以printf打印出来的值是6000102
也许大部分的面试,问到这里估计就结束了,可以得满分了。
不过在我看来,顶多能得30分。

 

 很明显这个题的是一个编译器实现相关的问题。还应该考虑些什么呢?

1.大小端的问题。在大端机器上,可能的答案是1020300

2.32bits或64bits地址的问题,如果是64bits地址和32bits整形(int)的话,很明显(int)a这句话就会有问题了

3.int的大小一定是32bits吗?当然不是了,C99标准中如下说
   5.2.4.2.1Sizes of integer types <limits.h>

    ...

       Their implementation-defined values shall be equal or greater in magnitude (absolutevalue) to those shown, with the same sign.

    ...

   —maximum value for an object of type unsigned int

   UINT_MAX65535 // 2^16 - 1

4. unsigned int *b0 = (unsigned int*)((int)a + 1);这句话真的是安全的吗?

     必然不是的,整个这个语句就是一个implementation-defined的,C99标准如下说

     An integer may be converted to any pointer type. Except as previously specified, the result is implementation-defined, might not be correctly aligned, might not point to an entity of the referenced type, and might be atrap representation.

     Any pointer type may be converted to an integer type. Except as previously specified, the result is implementation-defined. If the result cannot be represented in the integer type, the behavior is undefined. The result need not be in the range of values of any integer type.

 

假设我是面试官的话,能答出大小端和64bits,就是蛮不错的了

至于答出第3,4点就比较困难了,会阅读C99标准的应该不多。

标准中是否还有其他和这个题相关,我也不知道,我也没有通读C99标准。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值