Java中對(duì)象與C++中對(duì)象的放置安排的對(duì)比
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)文章
java獲取系統(tǒng)路徑字體、得到某個(gè)目錄下的所有文件名、獲取當(dāng)前路徑
這篇文章主要介紹了java獲取系統(tǒng)路徑字體、得到某個(gè)目錄下的所有文件名、獲取當(dāng)前路徑,需要的朋友可以參考下2014-04-04Java實(shí)現(xiàn)產(chǎn)生隨機(jī)字符串主鍵的UUID工具類
這篇文章主要介紹了Java實(shí)現(xiàn)產(chǎn)生隨機(jī)字符串主鍵的UUID工具類,涉及java隨機(jī)數(shù)與字符串遍歷、轉(zhuǎn)換等相關(guān)操作技巧,需要的朋友可以參考下2017-10-10使用jpa之動(dòng)態(tài)插入與修改(重寫save)
這篇文章主要介紹了使用jpa之動(dòng)態(tài)插入與修改(重寫save),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11JavaWeb學(xué)習(xí)過程之MVC查詢模式詳解
這篇文章主要介紹了JavaWeb學(xué)習(xí)過程之MVC查詢模式詳解的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09Spring @ComponentScan注解使用案例詳細(xì)講解
@ComponentScan注解的作用可以簡(jiǎn)述為:將項(xiàng)目中所有被@Component注解直接或者間接標(biāo)記的類---->組裝成BeanDefinition---->然后以key=beanName, value=BeanDefinition的形式存儲(chǔ),為后續(xù)生成bean對(duì)象做準(zhǔn)備2023-03-03