无法在 C++ 中的循环中将项目添加到链表

Can't add items to linked list in a loop in C++

我已经开始学习C++,作为第一个项目,我正在尝试制作一个链表应用程序。到目前为止,我对链表概念没有任何实际问题,因为我以前用不同的语言使用过它。

到目前为止,我已经有了将项目添加到列表并打印它的工作功能。在 main() class 中,我可以一个接一个地添加项目,但是当我尝试通过 for 或 while 循环添加多个项目时。

我有单独的函数来创建项目并将其添加到列表(的开头):

ListItem createItem(int value)
{
    ListItem x;
    std::cout << &x;
    x.value = value;

    return x;
}

void addBeg(ListItem* &start, ListItem &item)
{
    // Adding to an empty list
    if (start == nullptr)
    {
        item.prev = &item;
        item.next = &item;
    }
    else
    {
        std::cout << std::endl <<"X" &item;
        item.prev = (*start).prev;
        (*item.prev).next = &item;
        item.next = start;
        (*start).prev = &item;

    }
    start = &item;
}

我的 main() 函数如下所示:

int main(void)
{
    using namespace std;

    // List is empty at the beginning.
    ListItem* start = nullptr;

    printList(start);

    // This doesn't work:
    int i = 0;
    while (i < 10)
    {
        ListItem a = createItem(i);
        addBeg(start, a);
        i++;
    }

    // This works:
    addBeg(start, createItem(12));
    addBeg(start, createItem(13));
    addBeg(start, createItem(-42));
    addBeg(start, createItem(1));
    addBeg(start, createItem(-85));

    printList(start);

    return 0;
}

我似乎不明白为什么它不起作用。我想到的一个原因是 ListItem a 不会在每次迭代中重置,但这对我来说没有任何意义。感谢任何帮助或想法。

createItem 函数 returns 的值 ,当直接将其传递给另一个函数时(就像你对 addBeg(start, createItem(12)) returned 值是 temporary。获取并保存临时值的地址将导致 undefined行为.

简单的解决方案是 createItem 使用 new 和 return 指针动态 创建堆的节点。