在C ++ STL中列出pop_front()函数

在本文中,我们将讨论C ++中pop_front()函数的工作,语法和示例。

什么是STL中的列表

列表是一种数据结构,允许按时间顺序在任意位置进行插入和删除。列表被实现为双向链接列表。列表允许非连续的内存分配。与数组,向量和双端队列相比,列表在容器中的任何位置执行元素的插入提取和移动效果更好。在列表中,对元素的直接访问很慢,并且列表与forward_list相似,但是转发列表对象是单个链接列表,并且只能迭代转发。

什么是pop_front()

pop_front()是C ++ STL中的内置函数,在头文件中声明。pop_front()用于从列表容器的开头弹出(删除)元素。该函数删除列表容器的第一个元素,意味着该容器的第二个元素成为第一个元素,并且该容器中的第一个元素从该容器中删除。此功能将容器的尺寸减小1。

语法

void pop_front ();

此函数不接受任何参数

返回值

此函数不返回任何内容,只是从容器中删除/弹出第一个元素。

示例

#include <bits/stdc++.h>
using namespace std;
int main(){
   //创建一个列表
   list<int> myList;
   //将元素插入列表
   myList.push_back(1);
   myList.push_back(2);
   myList.push_back(3);
   myList.push_back(4);
   //应用pop_front()函数之前列出
   cout<<"List contains : ";
   for(auto i = myList.begin(); i != myList.end(); i++)
      cout << *i << " ";
   //删除第一个元素
   myList.pop_front();
   //从前面删除元素后的列表
   cout<<"\nList after removing an element from front: ";
   for (auto i = myList.begin(); i != myList.end(); i++)
      cout << *i << " ";
   return 0;
}

输出结果

如果我们运行上面的代码,那么它将生成以下输出

List contains : 1 2 3 4
List after removing an element from front: 2 3 4

示例

#include <iostream>
#include <list>
int main (){
   std::list<int> myList;
   myList.push_back (10);
   myList.push_back (20);
   myList.push_back (30);
   std::cout<<"removing the elements in a list : ";
   while (!myList.empty()){
      std::cout << ' ' << myList.front();
      myList.pop_front();
   }
   std::cout<<"\nSize of my empty list is: " << myList.size() << '\n';
   return 0;
}

输出结果

如果我们运行上面的代码,那么它将生成以下输出

removing the elements in a list : 10 20 30
Size of my empty list is: 0