C++之實(shí)現(xiàn)快速清空vector以及釋放vector內(nèi)存
C++快速清空vector以及釋放vector內(nèi)存
為什么需要主動(dòng)釋放vector內(nèi)存
vector其中一個(gè)特點(diǎn):內(nèi)存空間只會(huì)增長(zhǎng),不會(huì)減小,援引C++ Primer:為了支持快速的隨機(jī)訪問(wèn),vector容器的元素以連續(xù)方式存放,每一個(gè)元素都緊挨著前一個(gè)元素存儲(chǔ)。
設(shè)想一下,當(dāng)vector添加一個(gè)元素時(shí),為了滿足連續(xù)存放這個(gè)特性,都需要重新分配空間、拷貝元素、撤銷舊空間,這樣性能難以接受。
因此STL實(shí)現(xiàn)者在對(duì)vector進(jìn)行內(nèi)存分配時(shí),其實(shí)際分配的容量要比當(dāng)前所需的空間多一些。
就是說(shuō),vector容器預(yù)留了一些額外的存儲(chǔ)區(qū),用于存放新添加的元素,這樣就不必為每個(gè)新元素重新分配整個(gè)容器的內(nèi)存空間。
在調(diào)用push_back時(shí),每次執(zhí)行push_back操作,相當(dāng)于底層的數(shù)組實(shí)現(xiàn)要重新分配大??;這種實(shí)現(xiàn)體現(xiàn)到vector實(shí)現(xiàn)就是每當(dāng)push_back一個(gè)元素,都要重新分配一個(gè)大一個(gè)元素的存儲(chǔ),然后將原來(lái)的元素拷貝到新的存儲(chǔ),之后在拷貝push_back的元素,最后要析構(gòu)原有的vector并釋放原有的內(nèi)存。
怎么釋放vector的內(nèi)存
A、對(duì)于數(shù)據(jù)量不大的vector,沒(méi)有必要自己主動(dòng)釋放vector,一切都交給操作系統(tǒng)。
B、但是對(duì)于大量數(shù)據(jù)的vector,在vector里面的數(shù)據(jù)被刪除后,主動(dòng)去釋放vector的內(nèi)存就變得很有必要了!
由于vector的內(nèi)存占用空間只增不減,比如你首先分配了10000個(gè)字節(jié),然后erase掉后面9999個(gè),留下一個(gè)有效元素,但是內(nèi)存占用仍為10000個(gè)。所有內(nèi)存空間是在vector析構(gòu)時(shí)候才能被系統(tǒng)回收。empty()用來(lái)檢測(cè)容器是否為空的,clear()可以清空所有元素。但是即使clear(),vector所占用的內(nèi)存空間依然如故,無(wú)法保證內(nèi)存的回收。如果需要空間動(dòng)態(tài)縮小,可以考慮使用deque。如果vector,可以用swap()來(lái)幫助你釋放內(nèi)存。
示例代碼
新建一個(gè)控制臺(tái)程序,把代碼運(yùn)行起來(lái)看輸出,且看代碼:
#include <iostream> #include <vector> #include <string> #include <Windows.h> #include <Psapi.h> #pragma comment(lib, "Psapi.lib") using namespace std; //GetCurPorcessMemory bool GetCurProcessMemory(HANDLE handle, std::wstring& workingSize, std::wstring& peakWorkingSize) { //HANDLE handle = GetCurrentProcess(); PROCESS_MEMORY_COUNTERS pmc; if (GetProcessMemoryInfo(handle, &pmc, sizeof(pmc))) { int size = pmc.WorkingSetSize/1024; wchar_t buf[10] = {0}; _ltow(size, buf, 10); workingSize = std::wstring(buf); size = pmc.PeakWorkingSetSize/1024; _ltow(size, buf, 10); peakWorkingSize = std::wstring(buf); return true; } return false; } int _tmain(int argc, _TCHAR* argv[]) { std::wstring wszWorking, wszPeakWorking; vector<string> ary; for (int i=0; i<1000000; i++) { ary.push_back("hello vector"); } wchar_t wch; wcin >> wch; GetCurProcessMemory(GetCurrentProcess(), wszWorking, wszPeakWorking);// 此時(shí)檢查內(nèi)存情況 wcout << "Working : " << wszWorking.c_str() << " PeakWorking : " << wszPeakWorking.c_str() << endl; wcin >> wch; // ary.clear(); wcout << "vector clear" << endl; wcout << "vector capacity " << ary.capacity() << endl; GetCurProcessMemory(GetCurrentProcess(), wszWorking, wszPeakWorking);// 此時(shí)再次檢查 wcout << "Working : " << wszWorking.c_str() << " PeakWorking : " << wszPeakWorking.c_str() << endl; wcin >> wch; //vector<string>(ary).swap(ary); ary.swap(vector<string>(ary)); wcout << "vector swap" << endl; wcout << "vector capacity " << ary.capacity() << endl;// 此時(shí)容量為0 GetCurProcessMemory(GetCurrentProcess(), wszWorking, wszPeakWorking);// 檢查內(nèi)存 wcout << "Working : " << wszWorking.c_str() << " PeakWorking : " << wszPeakWorking.c_str() << endl; wcout << "vector size : " << ary.size() << endl;//0 //getchar(); system("pause"); return 0; }
C++清空vector元素的三種方式
//by 鳥(niǎo)哥 清空vector的三種方法 //有疑問(wèn)請(qǐng)留言或加群 1032082534 #include <iostream> #include <vector> using namespace std; int main(){ vector <int> vecInt; for (int i=0;i<50;i++) { vecInt.push_back(i); } cout<<"capacity:"<<vecInt.capacity(); //j=64 cout<<"size:"<<vecInt.size(); //i=50 cout<<endl; //1、使用clear ,清空元素,不回收空間 vecInt.clear(); cout<<"capacity:"<<vecInt.capacity(); //j=64 cout<<"size:"<<vecInt.size(); //i=50 cout<<endl; //2、erase循環(huán)刪除,不回收空間 for (int i=0;i<50;i++) { vecInt.push_back(i); } for ( vector <int>::iterator iter=vecInt.begin();iter!=vecInt.end();) { iter=vecInt.erase(iter); } cout<<"capacity:"<<vecInt.capacity(); //j=64 cout<<"size:"<<vecInt.size(); //i=50 cout<<endl; //3、使用swap,清除元素并回收內(nèi)存 vector <int>().swap(vecInt); //清除容器并最小化它的容量, // vecInt.swap(vector<int>()) ; 另一種寫(xiě)法 cout<<"capacity:"<<vecInt.capacity(); //j=0 cout<<"size:"<<vecInt.size(); //i=0 cout<<endl; }
運(yùn)行結(jié)果:
capacity:64size:50
capacity:64size:0
capacity:64size:0
capacity:0size:0
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
如何解決C++未定義標(biāo)識(shí)符 “string“、未定義標(biāo)識(shí)符 “cout“、“name”:未知重寫(xiě)說(shuō)明
在C++編程中,未定義標(biāo)識(shí)符"string"、"cout"錯(cuò)誤多因缺少頭文件引入造成,而"name":未知重寫(xiě)說(shuō)明符錯(cuò)誤則是未正確重寫(xiě)基類成員函數(shù),解決未定義標(biāo)識(shí)符錯(cuò)誤需正確引入<string>和<iostream>頭文件,對(duì)于未知重寫(xiě)說(shuō)明符錯(cuò)誤2024-09-09C++ Opencv自寫(xiě)函數(shù)實(shí)現(xiàn)膨脹腐蝕處理技巧
這篇文章主要介紹了C++ Opencv 自寫(xiě)函數(shù)實(shí)現(xiàn)膨脹腐蝕處理,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-10-10C++ 基于BFS算法的走迷宮自動(dòng)尋路的實(shí)現(xiàn)
這篇文章主要為大家介紹了C++ 基于BFS算法實(shí)現(xiàn)走迷宮自動(dòng)尋路,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11利用C語(yǔ)言實(shí)現(xiàn)經(jīng)典多級(jí)時(shí)間輪定時(shí)器
C語(yǔ)言是一門通用計(jì)算機(jī)編程語(yǔ)言,廣泛應(yīng)用于底層開(kāi)發(fā),這篇文章主要給大家介紹了關(guān)于利用C語(yǔ)言實(shí)現(xiàn)經(jīng)典多級(jí)時(shí)間輪定時(shí)器的相關(guān)資料,需要的朋友可以參考下2021-07-07Qt圖形圖像開(kāi)發(fā)之曲線圖表模塊QChart庫(kù)一個(gè)chart中顯示兩條曲線詳細(xì)方法與實(shí)例
這篇文章主要介紹了Qt圖形圖像開(kāi)發(fā)之曲線圖表模塊QChart庫(kù)一個(gè)chart中顯示兩條曲線詳細(xì)方法與實(shí)例,需要的朋友可以參考下2020-03-03