gpt4 book ai didi

c++ - 链表Front()函数语法错误

转载 作者:行者123 更新时间:2023-11-28 00:45:25 25 4
gpt4 key购买 nike

我试图在我的链表类的 Front() 方法中返回一个节点。 front 方法只返回链表中的第一个元素(即它是一个节点)。然而,编译器不喜欢这样。它给了我以下错误。

Error: initial reference value of reference to non-const must be an lvalue.

有人知道解决这个问题的方法吗? mHead 是 intellisense 下划线的部分。

Node &List::Front()
{
return mHead->getData();
}

Potion Node::getData()
{
return mData;
}

list.h

#ifndef LIST_H
#define LIST_H

#include "node.h"
#include "potion.h"

class List
{

public:
//Default constructor
List();

//Copy constructor
List(const List & copy);

//Overloaded assignment operator
List &operator=(const List & rhs);

//Destructor
~List();

//Methods
void PushFront(Node * newNode);
void PushBack(Node * newNode);
void PopFront();
void PopBack();
/*const Potion &Front() const;
const Potion &Back() const;*/
Node &Front();
Node &Back();
void Purge();
bool empty();
int getNumberOfNodes();
Node * CreateNode(Potion potion);
void Save(std::ofstream & file);
void Load(std::ifstream & file);

protected:
//Data members
Node * mHead;
Node * mTail;
static int mNumberOfNodes;
};

#endif

最佳答案

我猜您的 getData() 函数正在返回数据的拷贝而不是引用。临时对象不是左值

关于c++ - 链表Front()函数语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16428282/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com