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
的next指向自己。new和malloc並不是在堆疊上分配記憶體的,所以不會自動被釋放。
因為
l1
在堆疊上,每個循環都在相同的位址上,所以後面的值會覆蓋前面的。這裡應該使用new
。