欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++之實(shí)現(xiàn)快速清空vector以及釋放vector內(nèi)存

 更新時間:2023年08月07日 10:12:10   作者:hellokandy  
這篇文章主要介紹了C++之實(shí)現(xiàn)快速清空vector以及釋放vector內(nèi)存方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

C++快速清空vector以及釋放vector內(nèi)存

為什么需要主動釋放vector內(nèi)存

vector其中一個特點(diǎn):內(nèi)存空間只會增長,不會減小,援引C++ Primer:為了支持快速的隨機(jī)訪問,vector容器的元素以連續(xù)方式存放,每一個元素都緊挨著前一個元素存儲。

設(shè)想一下,當(dāng)vector添加一個元素時,為了滿足連續(xù)存放這個特性,都需要重新分配空間、拷貝元素、撤銷舊空間,這樣性能難以接受。

因此STL實(shí)現(xiàn)者在對vector進(jìn)行內(nèi)存分配時,其實(shí)際分配的容量要比當(dāng)前所需的空間多一些。

就是說,vector容器預(yù)留了一些額外的存儲區(qū),用于存放新添加的元素,這樣就不必為每個新元素重新分配整個容器的內(nèi)存空間。

在調(diào)用push_back時,每次執(zhí)行push_back操作,相當(dāng)于底層的數(shù)組實(shí)現(xiàn)要重新分配大小;這種實(shí)現(xiàn)體現(xiàn)到vector實(shí)現(xiàn)就是每當(dāng)push_back一個元素,都要重新分配一個大一個元素的存儲,然后將原來的元素拷貝到新的存儲,之后在拷貝push_back的元素,最后要析構(gòu)原有的vector并釋放原有的內(nèi)存。

怎么釋放vector的內(nèi)存

A、對于數(shù)據(jù)量不大的vector,沒有必要自己主動釋放vector,一切都交給操作系統(tǒng)。

B、但是對于大量數(shù)據(jù)的vector,在vector里面的數(shù)據(jù)被刪除后,主動去釋放vector的內(nèi)存就變得很有必要了!

由于vector的內(nèi)存占用空間只增不減,比如你首先分配了10000個字節(jié),然后erase掉后面9999個,留下一個有效元素,但是內(nèi)存占用仍為10000個。所有內(nèi)存空間是在vector析構(gòu)時候才能被系統(tǒng)回收。empty()用來檢測容器是否為空的,clear()可以清空所有元素。但是即使clear(),vector所占用的內(nèi)存空間依然如故,無法保證內(nèi)存的回收。如果需要空間動態(tài)縮小,可以考慮使用deque。如果vector,可以用swap()來幫助你釋放內(nèi)存。

示例代碼

新建一個控制臺程序,把代碼運(yùn)行起來看輸出,且看代碼:

#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);// 此時檢查內(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);// 此時再次檢查
	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;// 此時容量為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 鳥哥 清空vector的三種方法
//有疑問請留言或加群 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>()) ;     另一種寫法
    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é)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++重載的奧義之函數(shù)重載詳解

    C++重載的奧義之函數(shù)重載詳解

    函數(shù)重載是C++多態(tài)(靜態(tài)多態(tài))的特征體現(xiàn),它可以允許重復(fù)使用同一個函數(shù)名(籃子)的函數(shù),但是函數(shù)的參數(shù)列表(籃子裝的東西)是可以不一樣的。下面就簡單講講C++中函數(shù)重載的相關(guān)應(yīng)用吧
    2023-04-04
  • C++實(shí)現(xiàn)LeetCode(62.不同的路徑)

    C++實(shí)現(xiàn)LeetCode(62.不同的路徑)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(62.不同的路徑),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++面試八股文之位運(yùn)算問題詳解

    C++面試八股文之位運(yùn)算問題詳解

    這篇文章主要為大家介紹了C++面試八股文之位運(yùn)算的問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 四叉樹有損位圖壓縮處理程序示例

    四叉樹有損位圖壓縮處理程序示例

    這篇文章主要介紹了四叉樹有損位圖壓縮處理程序示例,可以對24位圖進(jìn)行壓縮,應(yīng)用于windows平臺,需要的朋友可以參考下
    2014-04-04
  • C++如何過濾出字符串的中文(GBK、UTF-8)

    C++如何過濾出字符串的中文(GBK、UTF-8)

    這篇文章主要給大家介紹了關(guān)于C++如何過濾出字符串的中文的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • c++用指針交換數(shù)組的實(shí)例講解

    c++用指針交換數(shù)組的實(shí)例講解

    下面小編就為大家分享一篇c++用指針交換數(shù)組的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11
  • 解析C++編程中的#include和條件編譯

    解析C++編程中的#include和條件編譯

    這篇文章主要介紹了解析C++編程中的#include和條件編譯,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • C語言Iniparser庫實(shí)現(xiàn)ini文件讀寫

    C語言Iniparser庫實(shí)現(xiàn)ini文件讀寫

    iniparser是針對INI文件的解析器。ini文件則是一些系統(tǒng)或者軟件的配置文件。本文就來介紹一下如何利用Iniparser庫實(shí)現(xiàn)ini文件讀寫吧
    2023-03-03
  • C語言數(shù)據(jù)結(jié)構(gòu)之迷宮問題

    C語言數(shù)據(jù)結(jié)構(gòu)之迷宮問題

    這篇文章主要為大家詳細(xì)介紹了C語言數(shù)據(jù)結(jié)構(gòu)之迷宮問題,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • C及C++?基礎(chǔ)循環(huán)示例詳解

    C及C++?基礎(chǔ)循環(huán)示例詳解

    這篇文章主要介紹了C及C++?中的循環(huán)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09

最新評論