java保存數(shù)據(jù)的方法:1、使用寄存器保存,是最快的保存區(qū)域;2、使用堆棧,會(huì)創(chuàng)建新的內(nèi)存;3、使用靜態(tài)存儲(chǔ),其將隨時(shí)等候調(diào)用;4、使用常數(shù)存儲(chǔ),是直接置于程序代碼內(nèi)部。
java保存數(shù)據(jù)的方法:
(1) 寄存器。
這是最快的保存區(qū)域,因?yàn)樗挥诤推渌斜4娣绞讲煌牡胤剑禾幚砥鲀?nèi)部。然而,寄存器的數(shù)量十分有限,所以寄存器是根據(jù)需要由編譯器分配。我們對(duì)此沒(méi)有直接的控制權(quán),也不可能在自己的程序里找到寄存器存在的任何蹤跡。
(2) 堆棧。
駐留于常規(guī)ram(隨機(jī)訪問(wèn)存儲(chǔ)器)區(qū)域,但可通過(guò)它的“堆棧指針”獲得處理的直接支持。堆棧指針若向下移,會(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ì)象并不放到其中。
(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í)間!
(4) 靜態(tài)存儲(chǔ)。
這兒的“靜態(tài)”(static)是指“位于固定位置”(盡管也在ram 里)。程序運(yùn)行期間,靜態(tài)存儲(chǔ)的數(shù)據(jù)將隨時(shí)等候調(diào)用??捎胹tatic 關(guān)鍵字指出一個(gè)對(duì)象的特定元素是靜態(tài)的。但java 對(duì)象本身永遠(yuǎn)都不會(huì)置入靜態(tài)存儲(chǔ)空間。
(5) 常數(shù)存儲(chǔ)。
常數(shù)值通常直接置于程序代碼內(nèi)部。這樣做是安全的,因?yàn)樗鼈冇肋h(yuǎn)都不會(huì)改變。有的常數(shù)需要嚴(yán)格地保護(hù),所以可考慮將它們置入只讀存儲(chǔ)器(rom)。
(6) 非ram 存儲(chǔ)。
若數(shù)據(jù)完全獨(dú)立于一個(gè)程序之外,則程序不運(yùn)行時(shí)仍可存在,并在程序的控制范圍之外。其中兩個(gè)最主要的例子便是“流式對(duì)象”和“固定對(duì)象”。對(duì)于流式對(duì)象,對(duì)象會(huì)變成字節(jié)流,通常會(huì)發(fā)給另一臺(tái)機(jī)器。而對(duì)于固定對(duì)象,對(duì)象保存在磁盤(pán)中。即使程序中止運(yùn)行,它們?nèi)钥杀3肿约旱臓顟B(tài)不變。對(duì)于這些類型的數(shù)據(jù)存儲(chǔ),一個(gè)特別有用的技巧就是它們能存在于其他媒體中。一旦需要,甚至能將它們恢復(fù)成普通的、基于ram 的對(duì)象。java 1.1 提供了對(duì)lightweight persistence 的支持。未來(lái)的版本甚至可能提供更完整的方案。
相關(guān)學(xué)習(xí)推薦:java基礎(chǔ)教程