大佬教程收集整理的这篇文章主要介绍了c – printf语句有效吗?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
int main() { struct a { struct a *next; struct a *prev; }; struct a *A[2]; printf("Address of (&(A[0])->next) = %p",(&(A[0])->next)); getch(); return 0; }
在上面的printf语句中,我正在访问“struct a”结构&的“next”指针.当我在dev编译器中运行程序时,它给了我有效的内存地址(虽然我还没有为它分配任何内存).对如何发生这种情况的解释将非常有帮助.
是否有任何内存分配给“下一个”& “prev”字段?
&(A[0])->next
它是下一个指针的地址(不是它指向的地方,而是指针本身的地址).并且下一个指针是struct a的第一个元素,因此next的地址与其封闭的a的地址相同.
因此,表达式是A [0]引用的结构a的地址.在您的原始代码中,您永远不会在那里分配任何内容,因此它只是一个打印的垃圾值.正如@alk在另一个答案中指出的那样,你可以初始化变量A中的两个指针,然后你会看到第一个打印的值(比如0x0).
顺便说一下,如果你想快速初始化A,那么就这样做,而不是使用更详细的memset():
struct a *A[2] = {0};
它做同样的事情(将两个指针设置为0).
虽然打印的值是垃圾,但代码可能不是非法的.这可能看起来很令人惊讶,但请看这里:Dereferencing an invalid pointer,then taking the address of the result – 你有类似的东西,但不可否认你通过解除引用结构的一个成员而不是简单地使用*而更进了一步.所以我心中的开放性问题是:假设当foo是一个指针时,& * foo总是合法的(如上面的链接所示),对于& foo-> bar来说同样适用吗?
以上是大佬教程为你收集整理的c – printf语句有效吗?全部内容,希望文章能够帮你解决c – printf语句有效吗?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。