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

C++內(nèi)存管理詳解使用方式

 更新時(shí)間:2022年04月24日 15:46:38   作者:一起慢慢變強(qiáng)  
內(nèi)存管理是C++最令人切齒痛恨的問(wèn)題,也是C++最有爭(zhēng)議的問(wèn)題,C++高手從中獲得了更好的性能更大的自由,C++菜鳥(niǎo)的收獲則是一遍—遍的檢查代碼和對(duì)C++的痛恨,但內(nèi)存管理在C++中無(wú)處不在,內(nèi)存泄漏幾乎在每個(gè)C++程序中都會(huì)發(fā)生,要想成為C++高手,內(nèi)存管理這關(guān)是必須過(guò)的

c++中內(nèi)存管理的方式

在c語(yǔ)言中,我們擁有malloc和free等函數(shù)可以對(duì)內(nèi)存進(jìn)行動(dòng)態(tài)管理

但是總體來(lái)說(shuō)不是很方便,所以c++擁有了一種新的方式來(lái)對(duì)內(nèi)存進(jìn)行管理:通過(guò)new和delete操作符來(lái)對(duì)內(nèi)存進(jìn)行動(dòng)態(tài)分配

new和delete操作符的使用方式

new操作符的使用方式:

#include<iostream>
using namespace std;
class A
{};
 
int main()
{
	int* p = new int(2);	//動(dòng)態(tài)分配一個(gè)int類(lèi)型的空間,還可以將它初始化
	int* p1 = new int[10];	//動(dòng)態(tài)分配一個(gè)數(shù)組
	A* p2 = new A;	//動(dòng)態(tài)分配一個(gè)類(lèi)
	return 0;
}

delete操作符的使用方式:

#include<iostream>
using namespace std;
class A
{};
int main()
{
	int* p = new int(2);
	int* p1 = new int[10];	
	A* p2 = new A;	
	delete p;	//銷(xiāo)毀p
	delete[] p1;	//銷(xiāo)毀p1
	delete p2;	//銷(xiāo)毀p2
	return 0;
}

注意:

1、對(duì)于自定義類(lèi)型,new和delete會(huì)自動(dòng)調(diào)用構(gòu)造函數(shù)和析構(gòu)函數(shù)對(duì)創(chuàng)建出的對(duì)象進(jìn)行初始化,也可以顯示的寫(xiě)出想要被初始化的值,而malloc和free不會(huì)

#include<iostream>
using namespace std;
class A
{
public:
	A(int x = 1) :_x(x) {}
private:
	int _x;
};
int main()
{
	A* p = new A(2);	//()括號(hào)內(nèi)為顯示的給對(duì)象初始化的值
	return 0;
}

2、假如要銷(xiāo)毀數(shù)組類(lèi)的內(nèi)容,最好使用[]來(lái)修飾一下,因?yàn)殡m然對(duì)于內(nèi)置類(lèi)型不會(huì)報(bào)錯(cuò),但是自定義類(lèi)型會(huì)直接報(bào)錯(cuò)

operator new和operator delete函數(shù)

new和delete是用戶進(jìn)行動(dòng)態(tài)內(nèi)存申請(qǐng)和釋放的操作符

operator new 和operator delete是系統(tǒng)提供的全局函數(shù)

new在底層調(diào)用operator new全局函數(shù)來(lái)申請(qǐng)空間

delete在底層通過(guò)operator delete全局函數(shù)來(lái)釋放空間

最終還是通過(guò)malloc和free來(lái)進(jìn)行動(dòng)態(tài)內(nèi)存分配,不過(guò)和c不同的是,c++空間申請(qǐng)失敗,會(huì)出現(xiàn)拋異常的情況,而不是返回NULL

new和delete的原理內(nèi)部實(shí)現(xiàn)

內(nèi)置類(lèi)型

如果申請(qǐng)的是內(nèi)置類(lèi)型的空間,new和malloc,delete和free基本類(lèi)似,不同的地方是:new/delete申請(qǐng)和釋放的是單個(gè)元素的空間,new[]和delete[]申請(qǐng)的是連續(xù)空間,而且new在申請(qǐng)空間失敗時(shí)會(huì)拋異常,malloc會(huì)返回NULL

自定義類(lèi)型

如果是自定義類(lèi)型,就有很大區(qū)別了

new的原理

1、調(diào)用operator new申請(qǐng)空間,

2、調(diào)用構(gòu)造自定義類(lèi)型的構(gòu)造函數(shù)進(jìn)行初始化

delete的原理

1、調(diào)用operator delete釋放空間

2、調(diào)用自定義類(lèi)型的析構(gòu)函數(shù)進(jìn)行初始化

所以我們使用c++的時(shí)候最好使用new和delete進(jìn)行動(dòng)態(tài)內(nèi)存開(kāi)辟,因?yàn)檫@樣可以更方便進(jìn)動(dòng)態(tài)內(nèi)存管理,防止內(nèi)存泄露

到此這篇關(guān)于C++內(nèi)存管理詳解使用方式的文章就介紹到這了,更多相關(guān)C++內(nèi)存管理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MFC實(shí)現(xiàn)連連看游戲之消子算法

    MFC實(shí)現(xiàn)連連看游戲之消子算法

    這篇文章主要為大家詳細(xì)介紹了MFC實(shí)現(xiàn)連連看游戲之消子算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • C語(yǔ)言strlen函數(shù)全方位講解

    C語(yǔ)言strlen函數(shù)全方位講解

    在C語(yǔ)言中我們要獲取字符串的長(zhǎng)度,可以使用strlen函數(shù),strlen函數(shù)計(jì)算字符串的長(zhǎng)度時(shí),直到空結(jié)束字符,但不包括空結(jié)束字符,因?yàn)?nbsp;strlen函數(shù)時(shí)不包含最后的結(jié)束字符的,因此一般使用strlen函數(shù)計(jì)算的字符串的長(zhǎng)度會(huì)比使用sizeof計(jì)算的字符串的字節(jié)數(shù)要小
    2022-09-09
  • C++實(shí)現(xiàn)一個(gè)簡(jiǎn)單的線程池的示例代碼

    C++實(shí)現(xiàn)一個(gè)簡(jiǎn)單的線程池的示例代碼

    本文主要介紹了C++實(shí)現(xiàn)一個(gè)簡(jiǎn)單的線程池的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • C++實(shí)現(xiàn)二叉樹(shù)的堂兄弟節(jié)點(diǎn)查詢

    C++實(shí)現(xiàn)二叉樹(shù)的堂兄弟節(jié)點(diǎn)查詢

    C++實(shí)現(xiàn)二叉樹(shù)的堂兄弟節(jié)點(diǎn)查詢,是指在二叉樹(shù)中,找到兩個(gè)節(jié)點(diǎn)深度相同但父節(jié)點(diǎn)不同的節(jié)點(diǎn),即為堂兄弟節(jié)點(diǎn)。實(shí)現(xiàn)這一功能可以通過(guò)遍歷二叉樹(shù)并記錄節(jié)點(diǎn)深度和父節(jié)點(diǎn)來(lái)實(shí)現(xiàn)
    2023-04-04
  • 判斷指定的進(jìn)程或程序是否存在方法小結(jié)(vc等)

    判斷指定的進(jìn)程或程序是否存在方法小結(jié)(vc等)

    VC判斷進(jìn)程是否存在?比如我想知道記事本是否運(yùn)行,要用到哪些函數(shù)等實(shí)例,需要的朋友可以參考下
    2013-01-01
  • C語(yǔ)言for語(yǔ)句用法詳解

    C語(yǔ)言for語(yǔ)句用法詳解

    今天,小編講訴C語(yǔ)言中循環(huán)語(yǔ)句(for)的使用方法,作為示例,以一個(gè)簡(jiǎn)單的例子講訴for語(yǔ)法。
    2015-11-11
  • 詳解QTreeWidget隱藏節(jié)點(diǎn)的兩種方式

    詳解QTreeWidget隱藏節(jié)點(diǎn)的兩種方式

    本文主要介紹了QTreeWidget隱藏節(jié)點(diǎn)的兩種方式,一種是直接隱藏,一種是間接隱藏,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C語(yǔ)言實(shí)現(xiàn) 數(shù)據(jù)類(lèi)型占多少字節(jié)指針占多少字節(jié)

    C語(yǔ)言實(shí)現(xiàn) 數(shù)據(jù)類(lèi)型占多少字節(jié)指針占多少字節(jié)

    這篇文章主要介紹了 C語(yǔ)言 數(shù)據(jù)類(lèi)型占多少字節(jié)指針占多少字節(jié)的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 深入理解C++編程中的局部變量和全局變量

    深入理解C++編程中的局部變量和全局變量

    這篇文章主要介紹了深入理解C++編程中的局部變量和全局變量,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • C++?STL容器適配器使用指南

    C++?STL容器適配器使用指南

    C++?STL(標(biāo)準(zhǔn)模板庫(kù))是一套功能強(qiáng)大的?C++?模板類(lèi),提供了通用的模板類(lèi)和函數(shù),這些模板類(lèi)和函數(shù)可以實(shí)現(xiàn)多種流行和常用的算法和數(shù)據(jù)結(jié)構(gòu),如向量、鏈表、隊(duì)列、棧,今天我們來(lái)探究一下stl容器適配器的使用吧
    2021-11-11

最新評(píng)論