看完了C语言谜题,收获颇多,进一步理解了C语言,从其中列出的每个例子中都能够学到很多之前被忽视的知识点。
这里记录几个不错的case.
下面的程序会输出什么?
#include <stdio.h> int main() { float a = 12.5; printf("%d\n", a); printf("%d\n", (int)a); printf("%d\n", *(int *)&a); return 0; }
参考答案:
该项程序输出如下所示,
0
12
1095237632
原因是:浮点数是4个字节,12.5f 转成二进制是:01000001010010000000000000000000,十六进制是:0×41480000,十进制是:1095237632。所以,第二和第三个输出相信大家也知道是为什么了。而对于第一个,为什么会输出0,我们需要了解一下float和double的内存布局,如下:
float: 1位符号位(s)、8位指数(e),23位尾数(m,共32位)
double: 1位符号位(s)、11位指数(e),52位尾数(m,共64位)
然后,我们还需要了解一下printf由于类型不匹配,所以,会把float直接转成double,注意,12.5的float和double的内存二进制完全不一样。别忘了在x86芯片下使用是的反字节序,高位字节和低位字位要反过来。所以:
float版:0×41480000 (在内存中是:00 00 48 41)
double版:0×4029000000000000 (在内存中是:00 00 00 00 00 00 29 40)
而我们的%d要求是一个4字节的int,对于double的内存布局,我们可以看到前四个字节是00,所以输出自然是0了。
这个示例向我们说明printf并不是类型安全的,这就是为什么C++要引如cout的原因了。
ATTENTION:
1,"hello"[2] == 2["hello"] = 'l'
2,C/C++中,以0开头的数字都是八进制的。
3,sizeof不是一个函数,是一个操作符,其求i++的类型的size,这是一件可以在程序运行前(编译时)完全的事情,所以,sizeof(i++)直接就被4给取代了,在运行时也就不会有了i++这个表达式。
4,switch-case体中的变量初始化语句不会被执行。
5,printf返回值是输出的字符个数。
6,stdout和stderr是不是同设备描述符。stdout是块设备,stderr则不是。对于块设备,只有当下面几种情况下才会被输入,1)遇到回车,2)缓冲区满,3)flush被调用。而stderr则不会。
本文出自 “About:Blank H4cking” 博客,请务必保留此出处http://pnig0s1992.blog.51cto.com/393390/814005
查看本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/Programming/C/
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索内存
, printf
, float
, c语言程序题
, double
, 字节
, 输出
, 语言 1 # 00
, c 语言 51 字节 扩展
, 循环谜题
, 自增谜题
40题
c语言键盘记录器、linux c语言记录时长、c语言记录时间、键盘记录 c语言、c语言听课记录,以便于您获取更多的相关知识。