曾经以为,C语言对我来说已经深入骨髓,所有语法细节早已烂熟于胸,直到我遇到了一道笔试题,一道丧心病狂的笔试题,才渐渐明白,图样!图森破!哎我还是太年轻。。。
原题代码复杂,记不住,但考核的关键语法点嘴脸如下:
// 失效的指针 int main(void) { void (*p)(); // 定义了一个指针 int a = 100; p = &a; // 让指针p指向了a printf("a: %dn", *p); // 将p的目标(即a)的值输出 }
下面是输出结果:
a: -3495729482452(乱码)
输出结果明显是一个乱码,但这个乱码究竟是啥玩意儿咧?我们将源代码稍作修改:
// 失效的指针 int main(void) { void (*p)(); // 定义了一个指针 int a = 100; p = &a; // 让指针p指向了a printf("&a: %#xn", &a); // 将a的地址以十六进制输出 printf("*p: %#xn", *p); // 将p的目标(即a)的值以十六进制输出 }
下面是输出结果:
&a: 0xbfb4788
*p: 0xbfb4788
两个输出居然完全一样!要知道,p里面就存放了a的地址,也就是说p本来就等于0xbfb4788,但是*p应该是p的目标,也就是100,但为什么还是一个地址呢? 将代码再改一下:
// 失效的指针 int main(void) { void (*p)(); // 定义了一个指针 int a = 100; p = &a; // 让指针p指向了a printf("p: %#xn", p); // 将指针p存储的地址以十六进制输出 printf("*p: %#xn", *p); // 将指针p的目标(即a)以十六进制输出 printf("**p: %#xn", **p); // 将不该输出的东西输出看看! }
下面是输出结果:
p: 0xbfb4788
*p: 0xbfb4788
**p:0xbfb4788 简直不敢相信自己的眼睛,在这段代码中,指针p仿佛中邪了,解引用符 * 对它不起作用了,不管p的前面加了多少个 *,始终无法得到p的目标,即a的值!
这是怎么回事咧?小伙伴,机智如你,将你的见解写入留言,给大家参考参考吧!
点击左下角 阅读原文,没时间慢聊了,快点上车!