队列链表出列功能



我目前正在学习各种链表队列和堆栈。我一直在读一些关于各种队列函数的注释。我很难理解提供的出列功能。

void CintQueue::Dequeue(int& item) //Remove front Item from the Queue
{
   Node *TempPtr;
   TempPtr = m_qFront;
   item = m_qFront->data;
   m_qFront = m_qFront->next;
   if (m_qFront == NULL)
       m_qRear = NULL;
   delete TempPtr;
}

我不明白为什么有一个参数被传递到队列外。它的目的是什么?我从代码中看到,它被分配了来自前端节点的数据值,但函数出列没有返回值,所以我不理解它的用途。有人能解释一下这个功能是如何工作的吗?是否需要一个单独的函数来获取从队列中删除的值?

函数参数传递了一个引用。因此,当它在函数中设置时,它会设置作为参数传递的变量:
CintQueue q;  // define queue
// fill q with ints
int i;
q.Dequeue(i);  // i is set here

您传递与队列的第一个对象具有相同类型的变量的引用。在该方法中,第一个项的数据被保存到该变量中,然后该项被删除。因此,只需一个函数调用就可以获取队列头项的数据并将其删除。

传递对函数的引用并为其赋值是void函数返回内容的一种方式。您也可以制作一个具有相同目的的方法,该方法带有返回值,并且不带参数。

相关内容

  • 没有找到相关文章

最新更新