當前位置

首頁 > 商務英語 > 計算機英語 > c中new的用法

c中new的用法

推薦人: 來源: 閱讀: 9K 次

下面小編就跟你們詳細介紹下c中new的用法的用法,希望對你們有用。

ing-bottom: 100%;">c中new的用法

  c中new的用法的用法如下:

一. 簡介

new有三種使用方式:plain new,nothrow new和placement new。

(1)plain new顧名思義就是普通的new,就是我們慣常使用的new。在C++中是這樣定義的:

void* operator new(std::size_t) throw(std::bad_alloc);

void operator delete(void *) throw();

提示:plain new在分配失敗的情況下,拋出異常std::bad_alloc而不是返回NULL,因此通過判斷返回值是否爲NULL是徒勞的。

(2)nothrow new是不拋出異常的運算符new的形式。nothrow new在失敗時,返回NULL。定義如下:

void * operator new(std::size_t,const std::nothrow_t&) throw();

void operator delete(void*) throw();

(3)placement new意即“放置”,這種new允許在一塊已經分配成功的內存上重新構造對象或對象數組。placement new不用擔心內存分配失敗,因爲它根本不分配內存,它做的唯一一件事情就是調用對象的構造函數。定義如下:

void* operator new(size_t,void*);

void operator delete(void*,void*);

提示1:palcement new的主要用途就是反覆使用一塊較大的動態分配的內存來構造不同類型的對象或者他們的數組。

提示2:placement new構造起來的對象或其數組,要顯示的調用他們的析構函數來銷燬,千萬不要使用delete。

char* p = new(nothrow) char[100];

long *q1 = new(p) long(100);

int *q2 = new(p) int[100/sizeof(int)];

二.實例

n new/delete.普通的new

定義如下:

void *operator new(std::size_t) throw(std::bad_alloc);

void operator delete(void*) throw();

注:標準C++ plain new失敗後拋出標準異常std::bad_alloc而非返回NULL,因此檢查返回值是否爲NULL判斷分配是否成功是徒勞的。

測試程序:

複製代碼 代碼如下:

#include "stdafx.h"

#include <iostream>

using namespace std;

char *GetMemory(unsigned long size)

{

char *p=new char[size];//分配失敗,不是返回NULL

return p;

}

int main()

{

try

{

char *p=GetMemory(10e11);// 分配失敗拋出異常std::bad_alloc

//...........

if(!p)//徒勞

cout<<"failure"<<endl;

delete [] p;

}

catch(const std::bad_alloc &ex)

{

cout<<()<<endl;

}

return 0;

}

row new/delete不拋出異常的運算符new的形式,new失敗時返回NULL。

定義如下:

複製代碼 代碼如下:

void *operator new(std::size_t,const std::nothrow_t&) throw();

void operator delete(void*) throw();

struct nothrow_t{}; const nothrow_t nothrow;//nothrow作爲new的標誌性啞元

測試程序:

複製代碼 代碼如下:

#include "stdafx.h"

#include <iostream>

#include <new>

using namespace std;

char *GetMemory(unsigned long size)

{

char *p=new(nothrow) char[size];//分配失敗,是返回NULL

if(NULL==p)

cout<<"alloc failure!"<<endl;

return p;

}

int main()

{

try

{

char *p=GetMemory(10e11);

//...........

if(p==NULL)

cout<<"failure"<<endl;

delete [] p;

}

catch(const std::bad_alloc &ex)

{

cout<<()<<endl;

}

return 0;

}

ement new/delete 主要用途是:反覆使用一塊較大的動態分配成功的內存來構造不同類型的對象或者它們的數組。例如可以先申請一個足夠大的字符數組,然後當需要時在它上面構造不同類型的對象或數組。placement new不用擔心內存分配失敗,因爲它根本不分配內存,它只是調用對象的構造函數。

測試程序:

複製代碼 代碼如下:

#include "stdafx.h"

#include <iostream>

#include <new>

using namespace std;

class ADT

{

int i;

int j;

public:

ADT()

{

}

~ADT()

{

}

};

int main()

{

char *p=new(nothrow) char[sizeof(ADT)+2];

if(p==NULL)

cout<<"failure"<<endl;

ADT *q=new(p) ADT; //placement new:不必擔心失敗

// delete q;//錯誤!不能在此處調用delete q;

q->ADT::~ADT();//顯示調用析構函數

delete []p;

return 0;

}

注:使用placement new構造起來的對象或數組,要顯式調用它們的析構函數來銷燬(析構函數並不釋放對象的內存),千萬不要使用delete.這是因爲placement new構造起來的對象或數組大小並不一定等於原來分配的內存大小,使用delete會造成內存泄漏或者之後釋放內存時出現運行時錯誤。