Cpp 对象模型探索 / placement new 实现原理
生活随笔
收集整理的這篇文章主要介紹了
Cpp 对象模型探索 / placement new 实现原理
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
一、placement new 調用過程
1、源代碼
#include <new>class CTest { public:int i_ = 0;int t_ = 0; };int main() {void *pbuffer = (void*)new char[sizeof(CTest)];CTest *ptest = new (pbuffer) CTest();return 0; }2、反匯編代碼
?3、查看C++源碼,獲取 operator new 的實現(xiàn)函數(shù),如下
inline void *operator new(size_t _Size, void* _Where) {(void)_Size;return _Where; }? ? ? ?這里我們發(fā)現(xiàn),placement?new 的 operator new 函數(shù)由于外部已經(jīng)給他分配了內(nèi)存,所以該函數(shù)沒有執(zhí)行 malloc 函數(shù),僅僅是將外部申請的內(nèi)存返回。
二、重載 placement new?
1、方法
void *operator new (size_t size,void *pbuffer) {size;return pbuffer; }2、上述函數(shù)若放在全局,則重載了全局 placement new 對應的 operator new 函數(shù)。
若放在類中,則重載了針對該類的 placement new 對應的 operator new 函數(shù)。
3、栗子
#include <new> #include <iostream>class CTest { public:int i_ = 0;int t_ = 0; public:/*** 重載的 placement new 對應的 operator new 函數(shù)。*/static void* operator new(size_t size,void *pbuffer); };void* CTest::operator new(size_t size, void* pbuffer) {size;std::cout << "執(zhí)行了類中的重載 placement new 函數(shù)。" << std::endl;return pbuffer; }int main() {void *pbuffer = (void*)new char[sizeof(CTest)];CTest *ptest = new (pbuffer) CTest();/*** placement new 標準的釋放方法。*/ptest->~CTest();delete[]pbuffer;return 0; }結果
執(zhí)行了類中的重載 placement new 函數(shù)。?三、總結
? ? ? ?1、placement new 并不會申請內(nèi)存,它只是在已經(jīng)申請的內(nèi)存上構建一個對象,即:執(zhí)行該對象的構造函數(shù)!
? ? ? ?2、格式:new (地址) classname () 。
? ? ? ?3、流程圖,如下:
?
(SAW:Game Over!)
總結
以上是生活随笔為你收集整理的Cpp 对象模型探索 / placement new 实现原理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 阻塞、非阻塞与同步、异步的区别
- 下一篇: Cpp 对象模型探索 / 系列文章的索引