我得到了一个没有被忽略的无效值,因为它应该是错误的,为什么

I am getting a void value not ignored as it ought to be error why?

本文关键字:因为 无效 为什么 错误 一个      更新时间:2023-10-16

rotate函数为void,有1个int参数。我不知道为什么我会犯这个错误。它只是一个有2条语句的void函数。

head_ptr_是一个私有链表变量。

getNodeAt返回位于给定位置"position"的节点。由于它返回了一个节点,我们可以访问它的成员分配工作从右到左。它在赋值之前完成操作数右侧的所有操作。如果我错了,请随意修正我的知识。

template <class T>
void LinkedList<T>::rotate(int k)
{
head_ptr_ = getNodeAt(k)->setNext(head_ptr_);//error here
head_ptr_ = getNodeAt(k-1)->setNext(nullptr);
}//end of rotate
template<class T>
Node<T>* LinkedList<T>::getNodeAt(int position) const
{
// Count from the beginning of the chain
Node<T>* cur_ptr = head_ptr_;
for (int skip = 0; skip < position; skip++)
cur_ptr = cur_ptr->getNext();
return cur_ptr;
}  // end getNodeAt
int main()
{
LinkedList<int> bag1;
for(int i = 14;i >= 10;i--)
{
bag1.insert(bag1.getLength(),i);
}
bag1.print();
cout << endl;
//bag1.invert();
bag1.rotate(3);
bag1.print();
system("PAUSE");
return 0;
}

错误:无效值未被忽略,因为它应该是

错误分析:

错误:无效值未被忽略。

这是一条GCC错误消息,表示函数的返回值为"void",但您正试图将其分配给非void变量。

您的特殊情况:
您的setNext((很可能返回void,并且您正试图将其返回结果存储到一个变量中,这就是为什么您在rotate函数中发布的这两行代码中提到了错误:

head_ptr_ = getNodeAt(k)->setNext(head_ptr_);//error here
head_ptr_ = getNodeAt(k-1)->setNext(nullptr);

您可以通过两种方式解决问题:

第一种解决方案:
将代码更改为这样,并应用必要的更改以保持相同的逻辑:

getNodeAt(k)->setNext(head_ptr_);
getNodeAt(k-1)->setNext(nullptr);

第二个解决方案:
更改setNext((函数以返回有效指针(不要忘记更改方法声明以返回节点指针(:

template<class T>
Node<T>* LinkedList<T>::setNext(Node<T>* next)
{
// same logic here as before
return ptr; // where ptr is a valid pointer that you want to return
}