new placement
new ? placement
你可以簡單的理解為C中的realloc,就是在已有空間的基礎(chǔ)上,重新分配一個(gè)空間,可以不破壞原來數(shù)據(jù),也可以把數(shù)據(jù)全部用新值覆蓋
一下是我搜集的一些筆記
如果你想在預(yù)分配的內(nèi)存上創(chuàng)建對象,用缺省的new操作符是行不通的。要解決這個(gè)問題,你可以用placement ? new構(gòu)造。它允許你構(gòu)造一個(gè)新對象到預(yù)分配的內(nèi)存上:
// ? buffer ? 是一個(gè)void指針 ? (void ? *)
// ? 用方括號[] ? 括起來的部分是可選的
[CYourClass ? * ? pValue ? = ? ] ? new( ? buffer) ? CYourClass[( ? parameters)];
下面是一些例子:
#include ? <new
class ? CTest
{
public:
CTest()
{}
CTest( ? int)
{}
/* ? 代碼*/
};
int ? main(int ? argc, ? char* ? argv[])
{
// ? 由于這個(gè)例子的目的,我們不考慮內(nèi)存對齊問題
char ? strBuff[ ? sizeof( ? CTest) ? * ? 10 ? + ? 100];
CTest ? * ? pBuffer ? = ? ( ? CTest ? *)strBuff;
// ? 缺省構(gòu)造
CTest ? * ? pFirst ? = ? new(pBuffer) ? CTest;
// ? 缺省構(gòu)造
CTest ? * ? pSecond ? = ? new(pBuffer ? + ? 1) ? CTest;
// ? 帶參數(shù)的構(gòu)造;
// ? 不理會(huì)的指針
new(pBuffer ? + ? 2) ? CTest( ? 5);
// ? 帶參數(shù)的構(gòu)造
CTest ? * ? pFourth ? = ? new( ? pBuffer ? + ? 3) ? CTest( ? 10);
// ? 缺省構(gòu)造
CTest ? * ? pFifth ? = ? new(pBuffer ? + ? 4) ? CTest();
// ? 構(gòu)造多個(gè)元素(缺省構(gòu)造)
CTest ? * ? pMultipleElements ? = ? new(pBuffer ? + ? 5) ? CTest[ ? 5];
return ? 0;
}
當(dāng)你有自己的內(nèi)存緩沖區(qū)或者在你實(shí)現(xiàn)自己的內(nèi)存分配策略的時(shí)候,placement ? new會(huì)很有用。事實(shí)上在STL中廣泛使用了placement ? new來給容器分配內(nèi)存;每個(gè)容器類都有一個(gè)模版參數(shù)說明了構(gòu)造/析構(gòu)對象時(shí)所用的分配器(allocator)。
在使用placement ? new的時(shí)候,你要記住以下幾點(diǎn):
加上頭文件#include ? <new ? 你可以用placement ? new構(gòu)造一個(gè)數(shù)組中的元素。 ? 要析構(gòu)一個(gè)用placement ? new分配的對象,你應(yīng)該手工調(diào)用析構(gòu)函數(shù)(并不存在一個(gè)“placement ? delete”)。它的語法如下:
pFirst-~CTest();
pSecond-~CTest();
//. ? . ? . ? 等等
總結(jié)
以上是生活随笔為你收集整理的new placement的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Redis分布式集群部署安装及细节(多主
- 下一篇: Hybris培训团购课程开团啦!