之前有一个错误认识,错误的认为局部变量的回收是发生在函数返回时。其实在块结束时块内使用的内容就会被回收了。
以下的实例说明了问题
int * p[2]; for (int i = 0; i < 2; ++i) { int item = i; p[i] = &item; } printf("p[0]=%p p[1]=%p ", p[0],p[1]); printf("*p[0]=%d *p[1]=%d ", *p[0],*p[1]);
某次的输出(具体的内存地址会有不同,但是依然会发现p[0]与p[1]指向了同一个地方)
p[0]=000000000023FE2C p[1]=000000000023FE2C *p[0]=1 *p[1]=1
这个问题的发现过程是使用struct时懒得手动释放内存,就试图将其都放在栈中,想等函数退出时令其自动回收。结果在for块中定义的变量会不断被回收,所有的都在同一个地址处。被struct封装一下,问题会更具有迷惑性。
typedef struct{ int item; }Node; int main(int argc, char const *argv[]) { Node * p[2]; for (int i = 0; i < 2; ++i) { Node node; node.item = i; p[i] = &node; } printf("p[0]=%p p[1]=%p ", p[0],p[1]); printf("p[0]->item=%d p[1]->item=%d ", p[0]->item,p[1]->item); }
输出如下
p[0]=000000000023FE20 p[1]=000000000023FE20 p[0]->item=1 p[1]->item=1