c++11&14-STL要點(diǎn)匯總
在c++里面不得不提的一個(gè)標(biāo)準(zhǔn)庫,就是STL,STL包含很多實(shí)用的數(shù)據(jù)結(jié)構(gòu),如vector,list,map,set等都是我們常用的,而c++11也對(duì)STL做了一些補(bǔ)充,使得STL的內(nèi)容越來越豐富,可選擇的也越來越多了。
1. std::array
先看一段代碼:
#include <array> #include <iostream> int main() { std::array<int, 4> arrayDemo = { 1,2,3,4 }; std::cout << "arrayDemo:" << std::endl; for (auto itor : arrayDemo) { std::cout << itor << std::endl; } int arrayDemoSize = sizeof(arrayDemo); std::cout << "arrayDemo size:" << arrayDemoSize << std::endl; return 0; }
從上面代碼可以看到,其實(shí)std::array
跟數(shù)組沒什么區(qū)別,只是增加了迭代器的功能。
2. std::forward_list
先看一段代碼:
#include <forward_list> #include <iostream> int main() { std::forward_list<int> numbers = {1,2,3,4,5,4,4}; std::cout << "numbers:" << std::endl; for (auto number : numbers) { std::cout << number << std::endl; } numbers.remove(4); std::cout << "numbers after remove:" << std::endl; for (auto number : numbers) { std::cout << number << std::endl; } return 0; }
std::forward_list
為c++11新增的線性表,與list
區(qū)別在于它是單向鏈表,而list
是雙向鏈表。我們?cè)趯W(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的時(shí)候都知道,鏈表在對(duì)數(shù)據(jù)進(jìn)行插入和刪除是比順序存儲(chǔ)的線性表有優(yōu)勢(shì),因此在插入和刪除操作頻繁的應(yīng)用場(chǎng)景中,使用list和forward_list
比使用array
、vector
和deque
效率要高很多。
3. std::unordered_map
先看一段代碼:
#include <iostream> #include <string> #include <unordered_map> int main() { std::unordered_map<std::string, std::string> mymap = { { "house","maison" }, { "apple","pomme" }, { "tree","arbre" }, { "book","livre" }, { "door","porte" }, { "grapefruit","pamplemousse" } }; unsigned n = mymap.bucket_count(); std::cout << "mymap has " << n << " buckets.\n"; for (unsigned i = 0; i<n; ++i) { std::cout << "bucket #" << i << " contains: "; for (auto it = mymap.begin(i); it != mymap.end(i); ++it) std::cout << "[" << it->first << ":" << it->second << "] "; std::cout << "\n"; } return 0; }
std::unordered_map
與std::map
用法基本差不多,但STL在內(nèi)部實(shí)現(xiàn)上有很大不同,std::map
使用的數(shù)據(jù)結(jié)構(gòu)為紅黑樹,且是有序的,而std::unordered_map
內(nèi)部是哈希表的實(shí)現(xiàn)方式,無序。哈希map理論上查找效率為O(1),但在存儲(chǔ)效率上,哈希map需要增加哈希表的內(nèi)存開銷。
4. std::unordered_set
先看一段代碼:
#include <iostream> #include <string> #include <unordered_set> #include <set> int main() { std::unordered_set<int> unorder_set; unorder_set.insert(7); unorder_set.insert(5); unorder_set.insert(3); unorder_set.insert(4); unorder_set.insert(6); std::cout << "unorder_set:" << std::endl; for (auto itor : unorder_set) { std::cout << itor << std::endl; } std::set<int> set; set.insert(7); set.insert(5); set.insert(3); set.insert(4); set.insert(6); std::cout << "set:" << std::endl; for (auto itor : set) { std::cout << itor << std::endl; } }
std::unordered_set
的數(shù)據(jù)存儲(chǔ)結(jié)構(gòu)也是哈希表的方式結(jié)構(gòu),除此之外,std::unordered_set
在插入時(shí)不會(huì)自動(dòng)排序,這是與set表現(xiàn)不同的地方,其他用法基本類似。
以上就是c++11&14-STL要點(diǎn)匯總的詳細(xì)內(nèi)容,更多關(guān)于c++11&14-STL的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
基于C++語言實(shí)現(xiàn)機(jī)動(dòng)車違章處罰管理系統(tǒng)
這篇文章主要介紹了基于C++語言實(shí)現(xiàn)機(jī)動(dòng)車違章處罰管理系統(tǒng)的相關(guān)資料,需要的朋友可以參考下2016-07-07完美解決QT?QGraphicsView提升到QChartView報(bào)錯(cuò)的問題
使用QT提供的QChartView來繪制圖表,提升QGraphicsView控件繼承QChartView后,然后將QGraphicsView提升到我們自己寫的類,怎么才能確保提升后編譯不報(bào)錯(cuò)呢,下面小編給大家?guī)砹薗T QGraphicsView 提升到QChartView報(bào)錯(cuò)解決方案,感興趣的朋友一起看看吧2023-05-05QT中QByteArray與char、int、float之間的互相轉(zhuǎn)化
本文主要介紹了QT中QByteArray與char、int、float之間的互相轉(zhuǎn)化,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05基于Matlab實(shí)現(xiàn)水波倒影特效的制作
這篇文章主要介紹了如何利用Matlab制作出水波倒影的特效,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Matlab有一定幫助,需要的可以參考一下2022-03-03詳解C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法
這篇文章主要介紹了C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-01-01C++中priority_queue的使用與模擬實(shí)現(xiàn)
本文主要介紹了C++中priority_queue的使用與模擬實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02