C++ 標(biāo)準(zhǔn)模板類詳解
1 標(biāo)準(zhǔn)模板庫(kù)
STL提供了表示容器、迭代器、函數(shù)對(duì)象和算法的模板。
- 容器:類似數(shù)組存儲(chǔ)若干值,切實(shí)同質(zhì)的;
- 迭代器:遍歷容器的對(duì)象,類似遍歷數(shù)組的指針,廣義指針;
- 算法:完成特定的任務(wù);
- 函數(shù)對(duì)象:類對(duì)象或函數(shù)指針。
模板類 vector
erase() 刪除矢量中給定區(qū)間元素。接受兩個(gè)迭代器參數(shù)(該參數(shù)定義了要?jiǎng)h除的區(qū)間),迭代器1指向區(qū)間起始處,迭代器2指向區(qū)間終止處的后一個(gè)位置。
// delete first and second elements data.erase(data.begin(), data.begin() + 2);
insert() 與erase() 功能相反。接受三個(gè)迭代器參數(shù)。param1 指定新元素插入位置,param2 和 param3 定義別插入的區(qū)間(通常是其他對(duì)象)。
// insert [old.begin + 1, old.end) in the front of data data.insert(data.begin(), old.begin() + 1, old.end()); // 此時(shí),超尾元素顯得十分方便 // 在末尾緊挨著插入元素 data.insert(data.end(), old.begin() + 1, old.end());
for_each() 接受三個(gè)參數(shù)。param1 和 param2 是定義容器中區(qū)間的迭代器,param3 指向函數(shù)的指針(函數(shù)對(duì)象)。將被指向的函數(shù)(param3)用于區(qū)間 [param1, param2) 的各個(gè)元素。但是被指向的函數(shù) param3 不可以修改區(qū)間的值。
// 代替for循環(huán)
for(auto iter = data.begin(); iter != data.end(); iter++) {
showData(*iter);
}
// replace for with for_each
// 注意此處的函數(shù)showData不能修改data的值。
for_each(data.begin(), data.end(), showData);
sort() 排序函數(shù)。
1)接受2個(gè)區(qū)間的迭代器參數(shù),對(duì)元素利用<運(yùn)算符進(jìn)行操作。
2)接受3個(gè)參數(shù),前兩個(gè)指定區(qū)間的迭代器,最后一個(gè)指向要是有的函數(shù)指針(對(duì)象)。這里的函數(shù)類似仿函數(shù)特性,但是形式不同于仿函數(shù)。
區(qū)分全排列(total ordering)和完整弱排序(strict weak ordering)。
// usage 1
sort(data.begin(), data.end());
// usage 2
bool compare(const structData& a, const structData& b) {
if(a.index == b.index) {
return a.data < b.data;
}
return a.index < b.index;
}
// sort with index from little to big, if index is equal, sort with data.
sort(data.begin(), data.end(), compare);
基于范圍 for 循環(huán)。不同于 for_each,基于范圍的for循環(huán)可以修改容器的內(nèi)容。
2.泛型編程
泛型編程旨在編寫(xiě)?yīng)毩⒂跀?shù)據(jù)結(jié)構(gòu)的代碼(即編寫(xiě)一套可以適用于所有數(shù)據(jù)結(jié)構(gòu)的函數(shù)代碼)。模板可以按照泛型定義函數(shù)或者類。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
解析VScode在Windows環(huán)境下c_cpp_properties.json文件配置問(wèn)題(推薦)
這篇文章主要介紹了解析VScode在Windows環(huán)境下c_cpp_properties.json文件配置問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
C++超詳細(xì)講解強(qiáng)制類型轉(zhuǎn)換的用法
在C++語(yǔ)言中新增了四個(gè)關(guān)鍵字static_cast、const_cast、reinterpret_cast和dynamic_cast。這四個(gè)關(guān)鍵字都是用于類型轉(zhuǎn)換的,類型轉(zhuǎn)換(type?cast),是高級(jí)語(yǔ)言的一個(gè)基本語(yǔ)法。它被實(shí)現(xiàn)為一個(gè)特殊的運(yùn)算符,以小括號(hào)內(nèi)加上類型名來(lái)表示,接下來(lái)讓我們一起來(lái)詳細(xì)了解2022-06-06
C++實(shí)現(xiàn)LeetCode(5.最長(zhǎng)回文子串)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(5.最長(zhǎng)回文子串),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
使用VS2019編譯CEF2623項(xiàng)目的libcef_dll_wrapper.lib的方法
這篇文章主要介紹了使用VS2019編譯CEF2623項(xiàng)目的libcef_dll_wrapper.lib的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
C語(yǔ)言堆排序經(jīng)典算法TopK問(wèn)題解析
這篇文章主要為大家介紹了C語(yǔ)言堆排序經(jīng)典算法TopK問(wèn)題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
C語(yǔ)言實(shí)現(xiàn)自行車存放管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)自行車存放管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
如何利用C++實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)的連接池詳解
為了提高M(jìn)ySQL數(shù)據(jù)庫(kù)的訪問(wèn)的瓶頸,除了在服務(wù)器端增設(shè)緩存服務(wù)器緩存常用的數(shù)據(jù)之外(如redis),還可以增加數(shù)據(jù)庫(kù)連接池,來(lái)提高M(jìn)ySQL Server的訪問(wèn)效率,這篇文章主要給大家介紹了關(guān)于如何利用C++實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)的連接池的相關(guān)資料,需要的朋友可以參考下2021-07-07

