最新C/C++中的new和delete的實現(xiàn)過程小結(jié)
下面是《C++ Primer 5th》中P726 對 new 和 delete 過程的解釋:
當(dāng)我們使用一條new表達(dá)式時,實際上執(zhí)行了三步操作:
- new表達(dá)式調(diào)用一個名為 operator new (或者 operator new[] )的標(biāo)準(zhǔn)庫函數(shù)。該函數(shù)分配一塊足夠大的、原始的、未命名的內(nèi)存空間以便存儲特定類型的對象(或者對象數(shù)組)。
- 編譯器運行相應(yīng)的構(gòu)造函數(shù)以構(gòu)造這些對象,并為其傳入初始值。
- 對象被分配了空間并構(gòu)造完成,返回一個指向該對象的指針。
當(dāng)我們使用一條delete表達(dá)式時,實際上執(zhí)行了兩步操作:
- 對sp所指的對象或者arr所指的數(shù)組中的元素執(zhí)行相應(yīng)的析構(gòu)函數(shù)。
- 編譯器調(diào)用名為 operator delete (或者 **operator delete[] **)的標(biāo)準(zhǔn)庫函數(shù)釋放內(nèi)存空間。
由于不同編譯器對new的實現(xiàn)過程不同,所以我們下面以侯捷老師課件來進(jìn)行詳解。
new
假設(shè)我們現(xiàn)在有一個類:complex.h
#ifndef __MYCOMPLEX__
#define __MYCOMPLEX__
class Complex {
public:
Complex(double r = 0, double i = 0) :m_real(r), m_imag(i) {}
double real() const { return m_real; }
double imag() const { return m_real; }
private:
double m_real;
double m_imag;
};
#endif
我們new一個對象
Complex* pc = new Complex(1,2);//Complex為類名(復(fù)數(shù))
編譯器處理new這一語句的時候,先分配復(fù)數(shù)的內(nèi)存,然后進(jìn)行轉(zhuǎn)型,最后調(diào)用構(gòu)造函數(shù),進(jìn)行了下面三個過程
void* men= operator new( sizeof(Complex));//第一步,分配內(nèi)存 pc = static_cast<Complex*>(men);//第二步,轉(zhuǎn)型 pc->Complex :: Complex(1,2);//第三步,調(diào)用構(gòu)造函數(shù)
下面是在VS2019上反匯編得到:

整體示意圖如下:

delete
當(dāng)我們進(jìn)行 delete 操作時:
delete pc;
在編譯器的處理過程中,這一語句轉(zhuǎn)化兩個步驟:先析構(gòu)再free
Complex::~Complex(pc);//析構(gòu)函數(shù) operator delete(pc);//釋放內(nèi)存
下面是在VS2019上反匯編得到:

示意圖如下:

整體代碼如下:
int main() {
Complex* pc = new Complex(1, 2);
cout << pc->imag() << ":" << pc->real() << endl;
delete pc;
system("pause");
return 0;
}
整體程序運行結(jié)果如下:

new[]
假設(shè)我們有一個類 MyString.h
#ifndef __MYSTRING__
#define __MYSTRING__
#include <string>
class MyString {
public:
MyString(const char* cstr = 0) {
if (cstr) {
m_data = new char[strlen(cstr) + 1];
strcpy(m_data, cstr);
}
else {
m_data = new char[1];
*m_data = '\0';
}
}
~MyString() {
delete[] m_data;
}
char* get_c_str() const { return m_data; }
private:
char* m_data;
};
#endif
我們new一個對象
MyString* ps = new MyString("Hello");編譯器處理new這一語句的時候,也是分為三個過程,與上相同
void* men= operator new( sizeof(MyString));//第一步,分配內(nèi)存
ps = static_cast<MyString*>(men);//第二步,轉(zhuǎn)型
ps->MyString:: MyString("Hello");//第三步,調(diào)用構(gòu)造函數(shù)下面是在VS2019上反匯編得到:

示意圖如下:

delete[]
當(dāng)我們進(jìn)行 delete 操作時:
delete ps;
在編譯器的處理過程中,這一語句轉(zhuǎn)化兩個步驟:先析構(gòu)再free
MyString::~MyString(ps);//析構(gòu)函數(shù) operator delete(ps);//釋放內(nèi)存
下面是在VS2019上反匯編得到:


示意圖如下:

整體代碼如下:
int main() {
MyString* ps = new MyString("Hello");
cout << ps->get_c_str() << endl;
delete ps;
system("pause");
return 0;
}整體程序運行結(jié)果如下:

到此這篇關(guān)于C/C++中的new和delete的實現(xiàn)過程的文章就介紹到這了,更多相關(guān)C++ new和delete內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ 數(shù)據(jù)結(jié)構(gòu)之水洼的數(shù)量算法
這篇文章主要介紹了C++ 數(shù)據(jù)結(jié)構(gòu)之水洼的數(shù)量算法的相關(guān)資料,需要的朋友可以參考下2017-06-06
C語言如何利用輾轉(zhuǎn)相除法求最大公約數(shù)
這篇文章主要介紹了C語言如何利用輾轉(zhuǎn)相除法求最大公約數(shù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08

