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。都可以在当前循环结束释放,只有上述方法不行。。。。
求解。。。
ローカル変数はステートメント ブロックを離れるとスタックからポップされます。
ListNode l1(i)
これは実際には非常に危険です。これは、ロジックが単純であるためです。最後に解放されたメモリ空間は、次のListNode l1(i)
によって埋め戻されます。最終的に、9
の次は自分自身を指します。new と malloc はスタックにメモリを割り当てないため、自動的に解放されません。
l1
はスタック上にあり、各ループで同じアドレスにあるため、後の値は前の値を上書きします。ここではnew
を使用する必要があります。