

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、棧內(nèi)存與堆內(nèi)存(Java)2012080715:40Java把內(nèi)存劃分成兩種:一種是棧內(nèi)存,一種是堆內(nèi)存。在函數(shù)中定義的一些基本類(lèi)型的變量和對(duì)象的引用變量都在函數(shù)的棧內(nèi)存中分配。當(dāng)在一段代碼塊定義一個(gè)變量時(shí),Java就在棧中為這個(gè)變量分配內(nèi)存空間,當(dāng)超過(guò)變量的作用域后,Java會(huì)自動(dòng)釋放掉為該變量所分配的內(nèi)存空間,該內(nèi)存空間可以立即被另作他用。堆內(nèi)存用來(lái)存放由new創(chuàng)建的對(duì)象和數(shù)組。在堆中分配的內(nèi)存,由Java虛擬機(jī)的自動(dòng)垃圾回收器來(lái)管
2、理。在堆中產(chǎn)生了一個(gè)數(shù)組或?qū)ο蠛?,還可以在棧中定義一個(gè)特殊的變量,讓棧中這個(gè)變量的取值等于數(shù)組或?qū)ο笤诙褍?nèi)存中的首地址,棧中的這個(gè)變量就成了數(shù)組或?qū)ο蟮囊米兞?。引用變量就相?dāng)于是為數(shù)組或?qū)ο笃鸬囊粋€(gè)名稱(chēng),以后就可以在程序中使用棧中的引用變量來(lái)訪(fǎng)問(wèn)堆中的數(shù)組或?qū)ο?。具體的說(shuō):棧與堆都是Java用來(lái)在Ram中存放數(shù)據(jù)的地方。與C不同,Java自動(dòng)管理?xiàng):投?,程序員不能直接地設(shè)置棧或堆。Java的堆是一個(gè)運(yùn)行時(shí)數(shù)據(jù)區(qū)類(lèi)的(對(duì)象從中分配空間。
3、這些對(duì)象通過(guò)new、newarray、anewarray和multianewarray等指令建立,它們不需要程序代碼來(lái)顯式的釋放。堆是由垃圾回收來(lái)負(fù)責(zé)的,堆的優(yōu)勢(shì)是可以動(dòng)態(tài)地分配內(nèi)存大小,生存期也不必事先告訴編譯器,因?yàn)樗窃谶\(yùn)行時(shí)動(dòng)態(tài)分配內(nèi)存的,Java的垃圾收集器會(huì)自動(dòng)收走這些不再使用的數(shù)據(jù)。但缺點(diǎn)是,由于要在運(yùn)行時(shí)動(dòng)態(tài)分配內(nèi)存,存取速度較慢。棧的優(yōu)勢(shì)是,存取速度比堆要快,僅次于寄存器,棧數(shù)據(jù)可以共享。但缺點(diǎn)是,存在棧中的數(shù)據(jù)大小與
4、生存期必須是確定的,缺乏靈活性。棧中主要存放一些基本類(lèi)型的變量(intshtlongbytefloatdoubleboolean)和對(duì)象句柄。棧有一個(gè)很重要的特殊性,就是存在棧中的數(shù)據(jù)可以共享。假設(shè)我們同時(shí)定義:inta=3intb=3編譯器先處理inta=3;首先它會(huì)在棧中創(chuàng)建一個(gè)變量為a的引用,然后查找棧中是否有3這個(gè)值,如果沒(méi)找到,就將3存放進(jìn)來(lái),然后將a指向3。接著處理intb=3;在創(chuàng)建完b的引用變量后,因?yàn)樵跅V幸呀?jīng)有3這個(gè)
5、值,便將b直接指向3。這樣,就出現(xiàn)了a與b同時(shí)均指向3的情況。這時(shí),如果再令a=4;那么編譯器會(huì)重新搜索棧中是否有4值,如果沒(méi)有,則將4存放進(jìn)來(lái),并令a指向4;如果已經(jīng)有了,則直接將a指向這個(gè)地址。因此a值的改變不會(huì)影響到b的值。要注意這種數(shù)據(jù)的共享與兩個(gè)對(duì)象的引用同時(shí)指向一個(gè)對(duì)象的這種共享是不同的,因?yàn)檫@種情況a的修改并不會(huì)影響到b,它是由編譯器完成的,它有利于節(jié)省空間。而一個(gè)對(duì)象引用變量修改了這個(gè)對(duì)象的內(nèi)部狀態(tài),會(huì)影響到另一個(gè)對(duì)象引
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 內(nèi)存分配方式,堆和棧區(qū)別
- 內(nèi)存區(qū)劃分、內(nèi)存分配、常量存儲(chǔ)區(qū)、堆、棧、自由存儲(chǔ)區(qū)、全局區(qū)[c++][內(nèi)存管理]
- java高內(nèi)存編程
- c++_java內(nèi)存分配
- c,c++內(nèi)存分配的詳細(xì)講解包括堆,棧,數(shù)據(jù)段等
- 內(nèi)存條的分類(lèi)及區(qū)別
- java內(nèi)存分配與管理是java的核心技術(shù)之一
- java內(nèi)存原型及工作原理簡(jiǎn)介
- Java內(nèi)存泄漏規(guī)約及其工具研究.pdf
- Java內(nèi)存泄漏發(fā)現(xiàn)技術(shù)研究.pdf
- java內(nèi)存的詳細(xì)分析(包括垃圾回收)
- 局部變量與全局變量區(qū)別,棧、堆和靜態(tài)存儲(chǔ)區(qū)的區(qū)別
- Java程序內(nèi)存使用分析技術(shù)研究.pdf
- 一個(gè)內(nèi)存模組上有多少內(nèi)存
- Java虛擬機(jī)的內(nèi)存管理策略的研究.pdf
- ecc內(nèi)存
- 面向新型混合內(nèi)存架構(gòu)的內(nèi)存管理機(jī)制.pdf
- 實(shí)時(shí)內(nèi)存數(shù)據(jù)庫(kù)的內(nèi)存數(shù)據(jù)組織管理.pdf
- 內(nèi)存分配
- 典型內(nèi)存計(jì)算系統(tǒng)的內(nèi)存開(kāi)銷(xiāo)評(píng)測(cè)研究.pdf
評(píng)論
0/150
提交評(píng)論