有点意思的C/C++问题及解答:21-25

有点意思的C/C++问题及解答:21-25

问题21:判断C编译器是否支持嵌套注释。

       解法:嵌套注释是指在/* */ 中出现/* ... */,定义这个式子: /*/*/0*/**/1  。如果编译器不支持嵌套注释,那么这个式子为0*1。如果支持嵌套注释,那么这个式子为1。摘自《C陷阱与缺陷》。

       问题22:判断机器的大小端。

       解法:用联合,先将其中的word赋值为0x12345678,然后打印数组bytes的元素。如果是大端,打印结果为12, 34, 56, 78;如果是小端,打印结果为78,56,34 ,12。

  1. union endian  
  2. {  
  3.     unsigned int word;  
  4.     unsigned char bytes[4];  
  5. };  

       问题23:用宏实现max的一个版本,其中max的参数都是整数,要求在宏max的定义中这些整型参数只被求值一次。

       解法:一般的我们会写成这样:

  1. #define max(a,b) ((a)>(b)? (a): (b))  
       但是这样存在问题,如果a是i++,那么上述宏展开后为 ((i++)>b)? (i++): (b)), i 可能会被加两次。如何避免这种情况呢?这是本题的关键。

       其实如果能用内联,写成内联函数是最好的。如果非要用宏,那么需要引入中间变量。如下定义:

  1. static int tmp1,tmp2;   
  2. #define max(a,b) (tmp1=(a),tmp2=(b),tmp1>tmp2? tmp1: tmp2)  
        问题24:数组与指针的区别。

       解答:摘自《C专家编程》。

       (1)数组:保存数据;指针:保存数据的地址。

       (2)数组:直接访问数据;指针:间接访问数据,首先取得指针的内容,把它作为地址,然后从地址提取数据

       (3)数组:通常用于存储固定数目前数据类型相同的元素;指针:通常用于动态数据结构

       (4)数组:隐式分配和删除;指针:相关的函数为malloc(),free()。

       (5)数组:自身即为数据名;指针,通常指向匿名数据。

        问题25:这个表达式能成为合法的C表达式吗?(x) ((x)-1)。

        解答:这个表达式看似奇怪,其实也是可能的。假如之前有下面定义: typedef x int,那么这个表达式等价与 (int) ((int)-1)。即将-1转为int类型两次。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值