堆內(nèi)存與棧內(nèi)存的區(qū)別_第1頁(yè)
堆內(nèi)存與棧內(nèi)存的區(qū)別_第2頁(yè)
堆內(nèi)存與棧內(nèi)存的區(qū)別_第3頁(yè)
堆內(nèi)存與棧內(nèi)存的區(qū)別_第4頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、棧內(nèi)存與堆內(nèi)存()把內(nèi)存劃分成兩種:一種是棧內(nèi)存,一種是堆內(nèi)存。在函數(shù)中定義的一些基本類型的變量和對(duì)象的引用變量都在函數(shù)的棧內(nèi)存中分配。當(dāng)在一段代碼塊定義一個(gè)變量時(shí),就在棧中為這個(gè)變量分配內(nèi)存空間,當(dāng)超過變量的作用域后,會(huì)自動(dòng)釋放掉為該變量所分配的內(nèi)存空間,該內(nèi)存空間可以立即被另作他用。堆內(nèi)存用來存放由創(chuàng)建的對(duì)象和數(shù)組。在堆中分配的內(nèi)存,由虛擬機(jī)的自動(dòng)垃圾回收器來管理。在堆中產(chǎn)生了一個(gè)數(shù)組或?qū)ο蠛螅€可以在棧中定義一個(gè)特殊的變量,讓棧中這個(gè)變量的取值等于數(shù)組或?qū)ο笤诙褍?nèi)存中的首地址,棧中的這個(gè)變量就成了數(shù)組或?qū)ο蟮囊米兞?。引用變量就相?dāng)于是為數(shù)組或?qū)ο笃鸬囊粋€(gè)名稱,以后就可以在程序中使用棧中

2、的引用變量來訪問堆中的數(shù)組或?qū)ο?。具體的說:棧與堆都是用來在中存放數(shù)據(jù)的地方。與不同,自動(dòng)管理?xiàng):投?,程序員不能直接地設(shè)置?;蚨?。的堆是一個(gè)運(yùn)行時(shí)數(shù)據(jù)區(qū)類的對(duì)象從中分配空間。這些對(duì)象通過、r和等指令建立,它們不需要程序代碼來顯式的釋放。堆是由垃圾回收來負(fù)責(zé)的,堆的優(yōu)勢(shì)是可以動(dòng)態(tài)地分配內(nèi)存大小,生存期也不必事先告訴編譯器,因?yàn)樗窃谶\(yùn)行時(shí)動(dòng)態(tài)分配內(nèi)存的,的垃圾收集器會(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ù)大小與生存期必須是確定的,缺乏靈活性。棧中主要存放一些基本類型的變量

3、()和對(duì)象句柄。棧有一個(gè)很重要的特殊性,就是存在棧中的數(shù)據(jù)可以共享。假設(shè)我們同時(shí)定義:編譯器先處理;首先它會(huì)在棧中創(chuàng)建一個(gè)變量為的引用,然后查找棧中是否有這個(gè)值,如果沒找到,就將存放進(jìn)來,然后將指向。接著處理;在創(chuàng)建完的引用變量后,因?yàn)樵跅V幸呀?jīng)有這個(gè)值,便將直接指向。這樣,就出現(xiàn)了與同時(shí)均指向的情況。這時(shí),如果再令=那么編譯器會(huì)重新搜索棧中是否有值,如果沒有,則將4存放進(jìn)來,并令,指向4;如果已經(jīng)有了,則直接將,指向這個(gè)地址。因此值的改變不會(huì)影響到的值。要注意這種數(shù)據(jù)的共享與兩個(gè)對(duì)象的引用同時(shí)指向一個(gè)對(duì)象的這種共享是不同的,因?yàn)檫@種情況的修改并不會(huì)影響到,它是由編譯器完成的,它有利于節(jié)省空間

4、。而一個(gè)對(duì)象引用變量修改了這個(gè)對(duì)象的內(nèi)部狀態(tài),會(huì)影響到另一個(gè)對(duì)象引用變量。是一個(gè)特殊的包裝類數(shù)據(jù)??梢杂茫簝煞N的形式來創(chuàng)建,第一種是用來(新)建對(duì)象的,它會(huì)在存放于堆中。每調(diào)用一次就會(huì)創(chuàng)建一個(gè)新的對(duì)象。而第二種是先在棧中創(chuàng)建一個(gè)對(duì)類的對(duì)象引用變量,然后查找棧中有沒有存放abc,如果沒有,則將abc存放進(jìn)棧,并令指向”abc”,如果已經(jīng)有”abc”則直接令指向“abc”。比較類里面的數(shù)值是否相等時(shí),用a方法;當(dāng)測(cè)試兩個(gè)包裝類的引用是否指向同一個(gè)對(duì)象時(shí),用=,下面用例子說明上面的理論。S,rings,r1=abc;S,rings,r2=abc;可以看出和是指向同一個(gè)對(duì)象的。abcS,rings,r

5、2=newS,ring(abc);Sys,em.ou,.prin,ln(s,r1=s,r2);/false用的方式是生成不同的對(duì)象。每一次生成一個(gè)。因此用第一種方式創(chuàng)建多個(gè)”abc”字符串在內(nèi)存中其實(shí)只存在一個(gè)對(duì)象而已這種寫法有利與節(jié)省內(nèi)存空間同時(shí)它可以在一定程度上提高程序的運(yùn)行速度,因?yàn)闀?huì)自動(dòng)根據(jù)棧中數(shù)據(jù)的實(shí)際情況來決定是否有必要?jiǎng)?chuàng)建新對(duì)象。而對(duì)于(的代碼,則一概在堆中創(chuàng)建新對(duì)象,而不管其字符串值是否相等,是否有擔(dān)心陷阱!方法才變量需要必要?jiǎng)?chuàng)建新對(duì)象,從而加重了程序的負(fù)擔(dān)。另一方面,要注意:我們?cè)谑褂弥T如abc的格式定義類時(shí),總是想當(dāng)然地認(rèn)為,創(chuàng)建了類的對(duì)象。類的性質(zhì),當(dāng)類,以提咼程序效率。對(duì)象可能并沒有被創(chuàng)建!而可能只是指向一個(gè)先前已經(jīng)創(chuàng)建的對(duì)象。只有通過能保證每次都創(chuàng)建一個(gè)新的對(duì)象。由于經(jīng)常變換其值時(shí),應(yīng)該考慮使用以下c練習(xí):生成幾個(gè)abc對(duì)象abc;abc;abcabcabcabc這句是關(guān)鍵!如果僅僅是這樣abcc?結(jié)果疋辟了一塊內(nèi)存。曰.cs因?yàn)橐米兞緾指向堆

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論