網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
queue介紹
只能訪(fǎng)問(wèn) queue<T> 容器適配器的第一個(gè)和最后一個(gè)元素。只能在容器的末尾添加新元素,只能從頭部移除元素。
許多程序都使用了 queue 容器。queue 容器可以用來(lái)表示超市的結(jié)賬隊(duì)列或服務(wù)器上等待執(zhí)行的數(shù)據(jù)庫(kù)事務(wù)隊(duì)列。對(duì)于任何需要用 FIFO 準(zhǔn)則處理的序列來(lái)說(shuō),使用 queue 容器適配器都是好的選擇。
調(diào)用#include< queue>
即可使用隊(duì)列類(lèi)
queue<Type,Container> (<數(shù)據(jù)類(lèi)型,容器類(lèi)型>)
初始化時(shí)必須要有數(shù)據(jù)類(lèi)型,容器可省略,省略時(shí)則默認(rèn)為deque類(lèi)型
queue<int>q1;
queue<double>q2;
queue<char>q3;
//默認(rèn)為用deque容器實(shí)現(xiàn)的queue;
queue<char, list<char>>q1;//用list容器實(shí)現(xiàn)的queue
queue<int, deque<int>>q2;//用deque容器實(shí)現(xiàn)的queue
queue 的生成方式和 stack 相同,下面展示如何創(chuàng)建一個(gè)保存字符串對(duì)象的
std::queue<std::string> words;
也可以使用拷貝構(gòu)造函數(shù):
std::queue<std::string> copy_words {words}; // A duplicate of words
stack<T>、queue<T> 這類(lèi)適配器類(lèi)都默認(rèn)封裝了一個(gè) deque<T> 容器,也可以通過(guò)指定第二個(gè)模板類(lèi)型參數(shù)來(lái)使用其他類(lèi)型的容器:
std::queue<std::string, std::list<std::string>>words;
底層容器必須提供這些操作:front()、back()、push_back()、pop_front()、empty() 和 size()。
注意:不能用vector容器初始化queue
因?yàn)閝ueue轉(zhuǎn)換器要求容器支持front()、back()、push_back()及 pop_front(),說(shuō)明queue的數(shù)據(jù)從容器后端入棧而從前端出棧。所以可以使用deque和list對(duì)queue初始化,而vector因其缺少pop_front(),不能用于queue。
queue常用函數(shù)
1.常用函數(shù)
- push() 在隊(duì)尾插入一個(gè)元素
- pop() 刪除隊(duì)列第一個(gè)元素
- size() 返回隊(duì)列中元素個(gè)數(shù)
- empty() 如果隊(duì)列空則返回true
- front() 返回隊(duì)列中的第一個(gè)元素
- back() 返回隊(duì)列中最后一個(gè)元素
2.函數(shù)運(yùn)用示例
1:push()在隊(duì)尾插入一個(gè)元素
queue <string> q; q.push("first"); q.push("second"); cout<<q.front()<<endl;
輸出 first
2:pop() 將隊(duì)列中最靠前位置的元素刪除,沒(méi)有返回值
queue <string> q; q.push("first"); q.push("second"); q.pop(); cout<<q.front()<<endl;
輸出 second
因?yàn)?first 已經(jīng)被pop()函數(shù)刪掉了
3:size() 返回隊(duì)列中元素個(gè)數(shù)
queue <string> q;
q.push("first");
q.push("second");
cout<<q.size()<<endl;
//輸出2,因?yàn)殛?duì)列中有兩個(gè)元素
4:empty() 如果隊(duì)列空則返回true
queue <string> q; cout<<q.empty()<<endl; q.push("first"); q.push("second"); cout<<q.empty()<<endl;
分別輸出1和0
最開(kāi)始隊(duì)列為空,返回值為1(ture);
插入兩個(gè)元素后,隊(duì)列不為空,返回值為0(false);
5:front() 返回隊(duì)列中的第一個(gè)元素
queue <string> q;
q.push("first");
q.push("second");
cout<<q.front()<<endl;
q.pop();
cout<<q.front()<<endl;
第一行輸出first;
第二行輸出second,因?yàn)閜op()已經(jīng)將first刪除了
6:back() 返回隊(duì)列中最后一個(gè)元素
queue <string> q;
q.push("first");
q.push("second");
cout<<q.back()<<endl;
輸出最后一個(gè)元素second
原文鏈接:https://blog.csdn.net/wteruiycbqqvwt/article/details/124640835
相關(guān)推薦
- 2022-04-06 .NET?Core使用CZGL.SystemInfo庫(kù)獲取主機(jī)運(yùn)行資源_基礎(chǔ)應(yīng)用
- 2022-01-30 取消radio的選中狀態(tài)
- 2022-08-17 C語(yǔ)言堆結(jié)構(gòu)處理TopK問(wèn)題詳解_C 語(yǔ)言
- 2022-06-10 基于PyQt5制作一個(gè)群發(fā)郵件工具_(dá)python
- 2022-03-15 could not open extension control file “/usr/pgsql-
- 2022-04-07 你知道怎么在?HTML?頁(yè)面中使用?React嗎_React
- 2022-05-20 關(guān)于Mybatis-plus中PaginationInterceptor分頁(yè)攔截器過(guò)時(shí)問(wèn)題解決辦法
- 2022-06-02 Android超詳細(xì)講解組件LinearLayout的使用_Android
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支