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