欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中對(duì)象與C++中對(duì)象的放置安排的對(duì)比

 更新時(shí)間:2017年09月22日 15:50:04   投稿:lqh  
這篇文章主要介紹了Java中對(duì)象與C++中對(duì)象的放置安排的對(duì)比的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下

Java中對(duì)象與C++中對(duì)象的放置安排的對(duì)比

概要:

Java中,所有的對(duì)象都存放在堆(Heap,一種通用的內(nèi)存池)中;而對(duì)象的引用是存放在堆棧(Stack)中的。
我們可以通過String直接聲明的字符串與new String聲明出來的字符串使用equals()和"=="進(jìn)行的比較,從而理解對(duì)象和引用的關(guān)系及它們的存儲(chǔ)位置。

堆棧是一種快速有效的分配存儲(chǔ)方法,僅次于寄存器。創(chuàng)建程序時(shí),Java系統(tǒng)必須知道存儲(chǔ)在堆棧內(nèi)所有項(xiàng)的確切生命周期,以便上下移動(dòng)堆棧指針。

堆不同于堆棧的好處是:編譯器不需要知道存儲(chǔ)的數(shù)據(jù)在堆里存活多長(zhǎng)時(shí)間。所以,堆比堆棧更加靈活。
Java中的堆棧并不能簡(jiǎn)單理解為數(shù)據(jù)結(jié)構(gòu)中的棧,雖然它們的英文都是Stack。Java中的堆棧是位于通用RAM(隨機(jī)訪問存儲(chǔ)器)中,但通過堆棧指針可以從處理器那里獲得直接支持。堆棧指針若向下移動(dòng),則分配新的內(nèi)存;若向上移動(dòng),則釋放那些內(nèi)存。

具體的Java的內(nèi)存分配請(qǐng)?jiān)斠姟禩hinking in Java》P22頁(yè)。

C++中:只要使用了new和malloc關(guān)鍵字聲明的對(duì)象,都是存放在堆中的,而malloc關(guān)鍵字也是對(duì)堆內(nèi)存進(jìn)行操作的:

A a(1);//棧中分配 
A b = A(1);//棧中分配 
A *c = new A(1);//堆中分配內(nèi)存空間,將在堆中所創(chuàng)建的對(duì)象存儲(chǔ)地址賦值給c指針 
A *d = (A*)malloc(sizeof(A));//堆中分配內(nèi)存空間 
delete c;

如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

最新評(píng)論