c++11&14-STL要點匯總
在c++里面不得不提的一個標準庫,就是STL,STL包含很多實用的數(shù)據(jù)結(jié)構(gòu),如vector,list,map,set等都是我們常用的,而c++11也對STL做了一些補充,使得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;
}
從上面代碼可以看到,其實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是雙向鏈表。我們在學習數(shù)據(jù)結(jié)構(gòu)的時候都知道,鏈表在對數(shù)據(jù)進行插入和刪除是比順序存儲的線性表有優(yōu)勢,因此在插入和刪除操作頻繁的應用場景中,使用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)部實現(xiàn)上有很大不同,std::map使用的數(shù)據(jù)結(jié)構(gòu)為紅黑樹,且是有序的,而std::unordered_map內(nèi)部是哈希表的實現(xiàn)方式,無序。哈希map理論上查找效率為O(1),但在存儲效率上,哈希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ù)存儲結(jié)構(gòu)也是哈希表的方式結(jié)構(gòu),除此之外,std::unordered_set在插入時不會自動排序,這是與set表現(xiàn)不同的地方,其他用法基本類似。
以上就是c++11&14-STL要點匯總的詳細內(nèi)容,更多關(guān)于c++11&14-STL的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C/C++?Qt?TreeWidget?單層樹形組件應用小結(jié)
TreeWidget?目錄樹組件,該組件適用于創(chuàng)建和管理目錄樹結(jié)構(gòu),在開發(fā)中我們經(jīng)常會把它當作一個升級版的ListView組件使用,本文將通過TreeWidget實現(xiàn)多字段顯示,并增加一個自定義菜單,通過在指定記錄上右鍵可彈出該菜單并對指定記錄進行操作2021-11-11
C語言入門篇--sizeof與strlen基礎(chǔ)理論
本篇文章是c語言基礎(chǔ)篇,主要為大家介紹了C語言的sizeof與strlen的基本理論知識,希望可以幫助大家快速入門c語言的世界,更好的理解c語言2021-08-08
C++中實現(xiàn)保存數(shù)據(jù)到CSV文件
這篇文章主要介紹了C++中實現(xiàn)保存數(shù)據(jù)到CSV文件方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08

