

1、寄存器 。這是最快的保存區(qū)域,因?yàn)樗挥诤推渌斜4娣绞讲煌牡胤剑禾幚砥鲀?nèi)部 。然而 , 寄存器的數(shù)量十分有限 , 所以寄存器是根據(jù)需要由編譯器分配 。我們對(duì)此沒有直接的控制權(quán),也不可能在自己的程序里找到寄存器存在的任何蹤跡 。
2、堆棧 。駐留于常規(guī)RAM(隨機(jī)訪問存儲(chǔ)器)區(qū)域 , 但可通過它的“堆棧指針”獲得處理的直接支持 。堆棧指針若向下移,會(huì)創(chuàng)建新的內(nèi)存;若向上移,則會(huì)釋放那些內(nèi)存 。這是一種特別快、特別有效的數(shù)據(jù)保存方式 , 僅次于寄存器 。創(chuàng)建程序時(shí),Java 編譯器必須準(zhǔn)確地知道堆棧內(nèi)保存的所有數(shù)據(jù)的“長(zhǎng)度”以及“存在時(shí)間” 。這是由于它必須生成相應(yīng)的代碼 , 以便向上和向下移動(dòng)指針 。這一限制無(wú)疑影響了程序的靈活性,所以盡管有些Java 數(shù)據(jù)要保存在堆棧里——特別是對(duì)象句柄,但Java 對(duì)象并不放到其中 。
【java怎么保存 java保存數(shù)據(jù)的方法】3、堆 。一種常規(guī)用途的內(nèi)存池(也在RAM 區(qū)域),其中保存了Java 對(duì)象 。和堆棧不同,“內(nèi)存堆”或“堆”(Heap)最吸引人的地方在于編譯器不必知道要從堆里分配多少存儲(chǔ)空間,也不必知道存儲(chǔ)的數(shù)據(jù)要在堆里停留多長(zhǎng)的時(shí)間 。因此,用堆保存數(shù)據(jù)時(shí)會(huì)得到更大的靈活性 。要求創(chuàng)建一個(gè)對(duì)象時(shí),只需用new 命令編制相關(guān)的代碼即可 。執(zhí)行這些代碼時(shí),會(huì)在堆里自動(dòng)進(jìn)行數(shù)據(jù)的保存 。當(dāng)然,為達(dá)到這種靈活性 , 必然會(huì)付出一定的代價(jià):在堆里分配存儲(chǔ)空間時(shí)會(huì)花掉更長(zhǎng)的時(shí)間 。
推薦閱讀
- 美食怎么畫 美食簡(jiǎn)筆畫教程
- 動(dòng)物園怎么畫 動(dòng)物園簡(jiǎn)筆畫教程
- 衛(wèi)生間吊頂怎么安裝 衛(wèi)生間吊頂如何安裝
- iPhone手機(jī)備忘錄怎么掃描圖片成pdf
- vep文件怎么打開
- 牛皮籃球怎么保養(yǎng) 牛皮籃球如何保養(yǎng)
- iPhone手機(jī)怎么設(shè)置無(wú)法接通的狀態(tài)
- 雨刮器關(guān)不掉怎么回事
- 家里無(wú)線網(wǎng)連不上怎么辦 家里無(wú)線網(wǎng)連不上解決方法
- 農(nóng)村停電了怎么查幾點(diǎn)來(lái)電 農(nóng)村停電了什么時(shí)候來(lái)電
