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