我正在尝试用C ++编写链接列表,但我遇到了一个问题。当我只插入一个项目时,它可以工作,但是当我插入多个项目时,它会进入一个无限循环。这是代码:
#include "linkedList.hpp"
#include <iostream>
linkedList::node::node(int value)
{
internalValue = value;
next = nullptr;
previous = nullptr;
};
linkedList::linkedList()
: header{node(-2)}, trailer{node(-2)}
{
trailer.previous = &header;
header.next = &trailer;
size = 0;
}
int linkedList::getLength()
{
return size;
}
void linkedList::appendElement(int value)
{
node newNode = node(value);
newNode.next = &trailer;
newNode.previous = trailer.previous;
(trailer.previous)->next = &newNode;
trailer.previous = &newNode;
size = size + 1;
}
void linkedList::print()
{
node * current = header.next;
while (current -> next != nullptr)
{
std::cout << current -> internalValue << "->" << "\n";
current = current->next;
}
std::cout << "v";
}
尝试调试之后,我发现问题在于构建节点。因此,当我第一次尝试插入5
时,程序会创建一个名为new node的节点,然后将其完全附加。
接下来发生的事情是当要追加第二个数字时,假设6
,程序并没有真正创建新的节点对象。而是变量名称&#34; newNode&#34;仍指向存储在其中的值为5
的节点,并将其替换为值为6
的节点。
这可以理解地创建一个无限循环,因为它基本上使数组循环。我不知道如何解决这个问题。有人能指出我正确的方向吗?
PS:对不起,如果这非常简单,我对C ++很新(这只是我编码的第二天)
答案 0 :(得分:3)
在linkedList::appendElement(int value)
中,您在堆栈上创建一个新节点(或'automatic storage'),这意味着该函数返回时将销毁该节点。
相反,使用new
运算符在堆上创建节点(或'dynamic storage'),以便在函数返回时不会销毁它。
node* newNode = new node(value);
当列表被销毁或截断时,您还必须记住自己销毁节点,并且大多数C ++开发人员很快就会发现使用智能指针更好。