C语言内存结构的研究

    技术2022-07-12  70

    考虑下面的一段代码

    #include <stdio.h> typedef struct{ int a[2]; double d; } struct_s; double fun(int i){ volatile struct_s s; s.d=3.14; s.a[i]=1073741824; printf("%f",s.d); return 0; } int main(){ fun(0); fun(1); fun(2); fun(3); fun(4); fun(5); // fun(6); // fun(7);

    在64位的ubunt上编译成a.out文件后执行,输出下列

    3.1400003.1400003.1400002.0000013.1400003.140000

    可以看到fun(3)中对a的修改影响了d的值,不过这和CSAPP上讲的并不一样,CSAPP上认为fun(2)就会影响 至于fun(6)是无法运行的,如果放开fun(6)的注释后编译运行,会报下列错误

    *** stack smashing detected ***: <unknown> terminated Aborted (core dumped)

    并且这个时候fun(0)到fun(5)也不会输出

    另外上面的fun函数的参数是负数也是可以运行的,此时d的值任然是3.14

    Processed: 0.027, SQL: 9