#include<stdio.h> #include<stdlib.h> #include<string.h> struct A{ int a; char b; }; struct B{ struct A *n; }; struct B *new_B(){ struct A t = { 100, 'c'}; struct B *p; p = (struct B *) malloc(sizeof(struct B)); p->n = &t; return p; } int main(void) { struct B *p; p = new_B(); printf("%d, %c\n", p->n->a, p->n->b); free(p); return 0; }
函數new_B的作用是新建一個結構體B的指針變量p,並為它分配內存,然後在函數中建立一個結構體A的變量t,並把這個變量的地址&t賦給B的成員n(n是結構體A的指針)。我們知道, t是一個局部變量,存放在棧中,在函數new_B執行結束後,t會被釋放。而當我們返回主函數,然後輸出,可以得到正確的結果。如果我們去掉分配內存這一行,也就是p = (struct B *) malloc(sizeof(struct B)); 執行就會出錯(這也是我想要得到的結果)。 問題是,就算分配了內存,new_B函數執行完以後t就會被釋放掉,那麼在主函數訪問 p->n是,應該也會出錯。為什麼在主函數中還可以訪問呢? 請大牛給予指導解答!!!