#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是,應該也會出錯。為什麼在主函數中還可以訪問呢? 請大牛給予指導解答!!!