struct ListNode {
int val;
ListNode *next;
ListNode(int x) : val(x), next(NULL) {}
};
for(int i=0;i<10;i++)
{
ListNode l1(i);
//此处将l1添加到链表中
}
这样的写法却会导致最后的链表结果全为9,也就是说虽然每一次都是将指针指向l1但是循环中l1从来没有被释放过。。。这是为什么?
我尝试过malloc和new。都可以在当前循环结束释放,只有上述方法不行。。。。
求解。。。
天蓬老师2017-04-17 15:23:58
ローカル変数はステートメント ブロックを離れるとスタックからポップされます。ListNode l1(i)
これは実際には非常に危険です。これは、ロジックが単純であるためです。最後に解放されたメモリ空間は、次の ListNode l1(i)
によって埋め戻されます。最終的に、9
の次は自分自身を指します。
new と malloc はスタックにメモリを割り当てないため、自動的に解放されません。