1樓:匿名使用者
1.new的作用是從自由儲存為 類 的物件或物件陣列分配記憶體,並將已適當分類的非零指標返回到物件。
比如:char * pchar= new char[10];
delete pchar;
例子中動態分配了10個char型別的記憶體給了pchar,來構成一個陣列。需要注意的是,分配陣列採用 ,如果只是單個的只要new char就可以了。
2.注意事項:
(1)使用 delete 運算子可解除分配使用 new 運算子分配的記憶體。而且new和delete是成對出現的。只出現一個是錯誤的或不規範的寫法,即使能編譯通過,也會有安全隱患,可能會造成記憶體洩露;
(2)使用的new與delete要相同。也就是說如果你在 new表示式中使用了 ,你必須在對應的 delete 表示式中使用 。如果你在 new 表示式中沒有使用 ,你也不必在對應的 delete 表示式中使用 。
(3)使用 new 為 c++ 類物件分配記憶體時,將在分配記憶體後呼叫物件的建構函式。所以如果是自己寫的類的話,最好自己寫個建構函式,這樣會比較好。
3.擴充套件資料參見
2樓:
new 的作用是動態開闢空間,一般的形式估計你也會了。我就直接給你講題吧
你這個函式的作用是動態建立一個(n1+1)*(n2+1)的二維陣列(注:在c++中 直接用new(a)這種形式是錯誤的)
首先明白所謂指標就是存放地址的變數,這一點最重要double **a=new double*[n1+1];
這句話的意思是開闢以一塊連續的空間用來儲存指標變數(指標的指標),它的大小是n1+1。*a是指標,那麼**a就是存放指標的指標。那個new後的double* 相當於一個強制轉換。
因為用new時和陣列的名字無關所以[n1+1]前的陣列名可以省略。這個類比於new double[3];
for(i=0;i<=n1;i++)
a[i]=new double[n2+1];
這個語句就是給把指標付給指標的指標,看下邊的圖你就明白了;
多琢磨一下!
3樓:_小_蘇
動態分配記憶體 相當於malloc
c++中new的用法
4樓:老表有點呈
c++中new運算子用於動態分配和撤銷記憶體的運算子。
1、開闢單變數地址空間
new int; //開闢一個存放陣列的儲存空間,返回一個指向該儲存空間的地址.int *a = new int 即為將一個int型別的地址賦值給整型指標a. 2)int *a = new int(5) 作用同上,但是同時將整數賦值為5。
2、開闢陣列空間
要訪問new所開闢的結構體空間,無法直接通過變數名進行,只能通過賦值的指標進行訪問。用new可以動態開闢,撤銷地址空間。在程式設計序時,若用完一個變數,下次需要再用,可以在每次開始使用時開闢一個空間,在用完後撤銷它。
5樓:手機使用者
new int;//開闢一個存放整數的儲存空間,返回一個指向該儲存空間的地址(即指標)
new int(100);//開闢一個存放整數的空間,並指定該整數的初值為100,返回一個指向該儲存空間的地址
new char[10];//開闢一個存放字元陣列(包括10個元素)的空間,返回首元素的地址
new int[5][4];//開闢一個存放二維整型陣列(大小為5*4)的空間,返回首元素的地址
float *p=new float (3.14159);//開闢一個存放單精度數的空間,並指定該實數的初值為//3.14159,將返回的該空間的地址賦給指標變數p
new運算子使用的一般格式為 new 型別 [初值] 用new分配陣列空間時不能指定初值。如果由於記憶體不足等原因而無法正常分配空間,則new會返回一個空指標null,使用者可以根據該指標的值判斷分配空間是否成功。
delete運算子使用的一般格式為 delete [ ] 指標變數
例如要撤銷上面用new開闢的存放單精度數的空間(上面第5個例子),應該用 delete p;
前面用“new char[10];”開闢的字元陣列空間,如果把new返回的指標賦給了指標變數pt,則應該用以下形式的delete運算子撤銷該空間:
delete pt;//在指標變數前面加一對方括號,表示是對陣列空間的操作
例 開闢空間以存放一個結構體變數。
#include
#include
using namespace std;
struct student //宣告結構體型別student
;int main( )
執行結果為 wang fun 10123 m
6樓:幸運夕夕
c++中new的用法有三種,具體如下:
一、new operator,也叫new表示式;new表示式比較常見,也最常用,例如:
上面這個new表示式完成了兩件事情:申請記憶體和初始化物件。
二、operator new,也叫new操作符。這兩個英文名稱起的也太絕了,很容易搞混,那就記中文名稱吧。new操作符類似於c語 言中的malloc,只是負責申請記憶體,例如:
注意: 這裡多了一個operator。這是new的第二個用法,也算比較常見吧。
三、placement new,它用於在給定的記憶體中初始化物件,也就是說你手中已有一塊閒置的記憶體,例如:
那麼現在buffer是你所擁有閒置記憶體的指標buffer = new(buffer) string("abc"); //呼叫了placement new,在buffer所指向的記憶體中初始化string型別的物件,初始值是"abc",事實上,placement new也是new表示式的一種,但是比普通的new表示式多了一個引數,當然完成的操作和返回值也不同。
因此上面new的第一種用法可以分解兩個 動作,分別為後面的兩種用法。
注意:1、使用者是無法主動呼叫建構函式的,所以需要藉助placement new,但是使用者可以主動呼叫解構函式,所以用完這些物件後,呼叫解構函式,然後用對應分配記憶體的方法去釋放記憶體。
2、事實上malloc並不一定比operatornew節省多少時間,用placement new常常是為了考慮效能,所以會配合記憶體池一起使用。
7樓:匿名使用者
new的功能是動態分配記憶體。
語法就是 new 型別名t(初值列表)
8樓:
new 的作用是動態開闢空間,一般的形式估計你也會了。我就直接給你講題吧
你這個函式的作用是動態建立一個(n1+1)*(n2+1)的二維陣列(注:在c++中 直接用new(a)這種形式是錯誤的)
首先明白所謂指標就是存放地址的變數,這一點最重要double **a=new double*[n1+1];
這句話的意思是開闢以一塊連續的空間用來儲存指標變數(指標的指標),它的大小是n1+1。*a是指標,那麼**a就是存放指標的指標。那個new後的double* 相當於一個強制轉換。
因為用new時和陣列的名字無關所以[n1+1]前的陣列名可以省略。這個類比於new double[3];
for(i=0;i<=n1;i++)
這個語句就是給把指標付給指標的指標,看下邊的圖你就明白了;
多琢磨一下!
9樓:有界函式
推薦你看一下effictive c++,這裡面有單獨的一節是講 new 的。細緻的講不了,可以自己去看看。
c++怎麼用new建立類物件?
10樓:
你是在類b的內部建立類a的物件麼?
那非常簡單,在類b的內部寫(private還是public塊都行,專根據具體情況
屬)a a;
或者a *a = new a();
當然前提是a的建構函式是無參的,如果有引數要寫上實參如果是說你的類b繼承了類a(即類b是類a的派生類),你想用new建立上轉型物件,就成了
a *a = new b();
11樓:匿名使用者
假設bai類名字為 t 使用語法 :t* object = new t(), 其中du
括號裡可以填寫類zhi初始化dao
的引數, 得到的 object 是一個版t型別的指標,別權忘了用delet object 釋放記憶體。
當c++程式用new 分配記憶體的時候,會比c的malloc 做一些額外的工作,尤其是使得類裡面使用的std標準庫型別的變數的到合適的初始化。此外,如果有自己編寫的記憶體管理器,new 還有一個變種: t* object = new (manager) t(), 如果需要, 請參考:
c++中new和delete的用法
12樓:肥仙女
在c++程式設計中,使用new分配的陣列可用delete釋放。這裡釋放的是動態分配的陣列空間,而不是靜態分配的陣列空間,詳細步驟:
1、例如,我們動態建立了一個一維int陣列arr,現在需要將它釋放。
2、這時只需要使用delete陣列名即可。
3、注意,要釋放陣列所佔的記憶體,不能少。否則,用delete則不能完全釋放陣列所佔記憶體空間。
4、例如,我們為一個二維陣列arr動態分配了記憶體空間。現在需要將它釋放。
5、這時候,單單使用一句deletearr是不夠的。
6、而是應該先釋放為二維陣列的每行分配的空間(即deletearr[i]),再釋放為行指標分配的空間(即deletearr)。
7、經過這樣兩步,動態分配的二維陣列空間才算徹底地釋放。至於多維陣列的釋放,其本質和二維陣列是相似的,可以參考二維陣列的方法。下圖為編譯執行截圖。
可以看到,順利執行,沒有非法的記憶體訪問,也沒有報錯。
13樓:文件類共創空間
對於計算機程式設計而言,變數和物件在記憶體中的分配都是編譯器在編譯程式時安排好的,這帶來了極大的不便,如陣列必須大開小用,指標必須指向一個已經存在的變數或物件。對於不能確定需要佔用多少記憶體的情況,動態記憶體分配解決了這個問題。
new和delete運算子是用於動態分配和撤銷記憶體的運算子。
一、new用法
1.開闢單變數地址空間
使用new運算子時必須已知資料型別,new運算子會向系統堆區申請足夠的儲存空間,如果申請成功,就返回該記憶體塊的首地址,如果申請不成功,則返回零值。
new運算子返回的是一個指向所分配型別變數(物件)的指標。對所建立的變數或物件,都是通過該指標來間接操作的,而動態建立的物件本身沒有識別符號名。
一般使用格式:
格式1:指標變數名=new 型別識別符號;
格式2:指標變數名=new 型別識別符號(初始值);
格式3:指標變數名=new 型別識別符號 [記憶體單元個數];
說明:格式1和格式2都是申請分配某一資料型別所佔位元組數的記憶體空間;但是格式2在記憶體分配成功後,同時將一初值存放到該記憶體單元中;而格式3可同時分配若干個記憶體單元,相當於形成一個動態陣列。例如:
1)new int; //開闢一個存放整數的儲存空間,返回一個指向該儲存空間的地址。int *a = new int 即為將一個int型別的地址賦值給整型指標a
2)int *a = new int(5) 作用同上,但是同時將整數空間賦值為5
2.開闢陣列空間
對於陣列進行動態分配的格式為:
指標變數名=new 型別名[下標表示式];
delete [ ] 指向該陣列的指標變數名;
兩式中的方括號是非常重要的,兩者必須配對使用,如果delete語句中少了方括號,因編譯器認為該指標是指向陣列第一個元素的指標,會產生**不徹底的問題(只**了第一個元素所佔空間),加了方括號後就轉化為指向陣列的指標,**整個陣列。
delete 的方括號中不需要填陣列元素數,系統自知。即使寫了,編譯器也忽略。
請注意“下標表示式”不必是常量表示式,即它的值不必在編譯時確定,可以在執行時確定。
一維: int *a = new int[100]; //開闢一個大小為100的整型陣列空間
二維: int **a = new int[5][6]
三維及其以上:依此類推.
一般用法: new 型別 (初值)
二、delete用法
1. 刪除單變數地址空間
int *a = new int;
delete a; //釋放單個int的空間
2. 刪除陣列空間
int *a = new int[5];
delete a; //釋放int陣列空間
三、使用注意事項
1. new 和delete都是內建的操作符,語言本身所固定了,無法重新定製,想要定製new和delete的行為,徒勞無功的行為。
2. 動態分配失敗,則返回一個空指標(null),表示發生了異常,堆資源不足,分配失敗。
3. 指標刪除與堆空間釋放。刪除一個指標p(delete p;)實際意思是刪除了p所指的目標(變數或物件等),釋放了它所佔的堆空間,而不是刪除p本身(指標p本身並沒有撤銷,它自己仍然存在,該指標所佔記憶體空間並未釋放),釋放堆空間後,p成了空指標。
4. 記憶體洩漏(memory leak)和重複釋放。new與delete 是配對使用的, delete只能釋放堆空間。
如果new返回的指標值丟失,則所分配的堆空間無法**,稱記憶體洩漏,同一空間重複釋放也是危險的,因為該空間可能已另分配,所以必須妥善儲存new返回的指標,以保證不發生記憶體洩漏,也必須保證不會重複釋放堆記憶體空間。
5. 動態分配的變數或物件的生命期。我們也稱堆空間為自由空間(free store),但必須記住釋放該物件所佔堆空間,並只能釋放一次,在函式內建立,而在函式外釋放,往往會出錯。
6. 要訪問new所開闢的結構體空間,無法直接通過變數名進行,只能通過賦值的指標進行訪問。
用new和delete可以動態開闢和撤銷地址空間。在程式設計序時,若用完一個變數(一般是暫時儲存的資料),下次需要再用,但卻又想省去重新初始化的功夫,可以在每次開始使用時開闢一個空間,在用完後撤銷它。
c中new的用法C中new的用法
c 中new運算子用於動態分配和撤銷記憶體的運算子。1 開闢單變數地址空間 new int 開闢一個存放陣列的儲存空間,返回一個指向該儲存空間的地址.int a new int 即為將一個int型別的地址賦值給整型指標a.2 int a new int 5 作用同上,但是同時將整數賦值為5。2 開闢...
C 用new建立類物件問題,C 怎麼用new建立類物件?
myclass a new myclass 這句話的意思是建立一個myclass型別的指標a,並生成一個myclass物件,使指標a指向這個物件。這個物件是匿名物件沒有名字。該物件沒有名字,但可以解指 針使用該物件,或者用引用 myclass b a 那麼b 和 a 表示同一回個物件了。如果 答my...
c中delete之後的再new問題
作為指標型簡單變數使用刪不刪,都可以用,就等於已宣告瞭 int p 指標本身已有儲存單版元。new int 是給它分配存權 放指向數值的單元。delete 只刪了 存放指向數值的單元。指標本身單元還在。只要它的使用符合語法,仍然可用。例如 a 2 b 3 p a printf d n p p b p...