讀think in java有感

....安全

2.2.1 保存到什麼地方指針

  程序運行時,咱們最好對數據保存到什麼地方作到心中有數。特別要注意的是內存的分配。有六個地方均可以保存數據:對象

  (1) 寄存器。這是最快的保存區域,由於它位於和其餘全部保存方式不一樣的地方:處理器內部。然而,寄存器的數量十分有限,因此寄存器是根據須要由編譯器分配。咱們對此沒有直接的控制權,也不可能在本身的程序裏找到寄存器存在的任何蹤影。繼承

  (2) 堆棧。駐留於常規RAM(隨機訪問存儲器)區域,但可經過它的「堆棧指針」得到處理的直接支持。堆棧指針若向下移,會建立新的內存;若向上移,則會釋放那些內存。這是一種特別快、特別有效的數據保存方式,僅次於寄存器。建立程序時,Java編譯器必須準確地知道堆棧內保存的全部數據的「長度」以及「存在時間」。這是因爲它必須生成相應的代碼,以便向上和向下移動指針。這一限制無疑影響了程序的靈活性,因此儘管有些Java數據要保存在堆棧裏——特別是對象句柄,但Java對象並不放到其中。進程

  (3) 堆。一種常規用途的內存池(也在RAM區域),其中保存了Java對象。和堆棧不一樣,「內存堆」或「堆」(Heap)最吸引人的地方在於編譯器沒必要知道要從堆裏分配多少存儲空間,也沒必要知道存儲的數據要在堆裏停留多長的時間。所以,用堆保存數據時會獲得更大的靈活性。要求建立一個對象時,只需用new命令編制相關的代碼便可。執行這些代碼時,會在堆裏自動進行數據的保存。固然,爲達到這種靈活性,必然會付出必定的代價:在堆裏分配存儲空間時會花掉更長的時間!內存

  (4) 靜態存儲。這兒的「靜態」(Static)是指「位於固定位置」(儘管也在RAM裏)。程序運行期間,靜態存儲的數據將隨時等候調用。可用static關鍵字指出一個對象的特定元素是靜態的。但Java對象自己永遠都不會置入靜態存儲空間。編譯器

  (5) 常數存儲。常數值一般直接置於程序代碼內部。這樣作是安全的,由於它們永遠都不會改變。有的常數須要嚴格地保護,因此可考慮將它們置入只讀存儲器(ROM)。io

  (6) 非RAM存儲。若數據徹底獨立於一個程序以外,則程序不運行時仍可存在,並在程序的控制範圍以外。其中兩個最主要的例子即是「流式對象」和「固定對象」。對於流式對象,對象會變成字節流,一般會發給另外一臺機器。而對於固定對象,對象保存在磁盤中。即便程序停止運行,它們仍可保持本身的狀態不變。對於這些類型的數據存儲,一個特別有用的技巧就是它們能存在於其餘媒體中。一旦須要,甚至能將它們恢復成普通的、基於RAM的對象。Java 1.1提供了對Lightweight persistence的支持。將來的版本甚至可能提供更完整的方案。編譯

 

4.4.2 構建器初始化class

  在這裏有必要總結一下對象的建立過程。請考慮一個名爲Dog的類:

  (1) 類型爲Dog的一個對象首次建立時,或者Dog類的static方法/static字段首次訪問時,Java解釋器必須找到Dog.class(在事先設好的類路徑裏搜索)。

  (2) 找到Dog.class後(它會建立一個Class對象,這將在後面學到),它的全部static初始化模塊都會運行。所以,static初始化僅發生一次——在Class對象首次載入的時候。

  (3) 建立一個new Dog()時,Dog對象的構建進程首先會在內存堆(Heap)裏爲一個Dog對象分配足夠多的存儲空間。

  (4) 這種存儲空間會清爲零,將Dog中的全部基本類型設爲它們的默認值(零用於數字,以及boolean和char的等價設定)。

  (5) 進行字段定義時發生的全部初始化都會執行。

  (6) 執行構建器。正如第6章將要講到的那樣,這實際可能要求進行至關多的操做,特別是在涉及繼承的時候。

相關文章
相關標籤/搜索