C语言内存结构的研究

考虑下面的一段代码

#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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章