- 初始化和清理正是涉及安全的兩個問題
一、用構造器確保初始化
構造器:在java中提供構造器,確保每個對象都會得到初始化。
在java中“創建”與“初始化”是捆綁在一起的,不能分離。
構造器采用與類相同的名字。
不接受任何參數的構造器叫做,默認構造器。也叫做無參構造器。
構造器是一種特殊類型的方法,因為它沒有返回值
二、方法重載
因為構造器只能與類同名,當用多種方式創建一個對象時,則需要多個構造器。
- 為了讓方法名相同而形式參數不同的構造器同時存在,必須使用方法重載
- 每個重載的方法都必須有一個獨一無二的參數類型列表。
三、默認構造器
- 如果類中沒有構造器,編譯器會自動創建一個默認構造器
四、this關鍵字
- this關鍵字只能在方法內部使用,表示對“調用方法的那個對象”的引用。
- 在一個構造器中調用另一個構造器
1、必須在構造器最起始處調用另一個構造器,且不能調用2個構造器
2、this調用構造器時,只能在構造器之內調用 - static方法就是沒有this的方法,static方法的內部不能調用非靜態方法,可以通過類本身訪問static方法
五、清理:終結處理和垃圾回收
- java內存中的垃圾回收
1、對象可能不被垃圾回收
2、垃圾回收并不等于“析構”
3、垃圾回收只與內存有關 - java允許定義一個名為finalize()的方法,它的需求被限制在一種特殊情況:通過某種創建對象方式以外的方式為對象分配了存儲空間。
此情況為在java中調用非java代碼
六、成員初始化
- 類的成員變量為基本類型時:會有一個自動初始值。
在定義成員變量時,應該直接提供初始值 - 初始化引用類型的方法
1、在定義對象的地方
2、在類的構造器中
3、惰性初始化,在使用這對象之前
4、實例初始化
public class Bath {
private String //在定義對象的地方初始化
s1 = "happy",
s2 = "happy",
s3,s4;
private Soap castille;
private int i;
private float toy;
private Bath(){ //在類的構造器中初始化
System.out.println("Inside Bath()");
s3 = "joy";
toy = 3.14f;
castille = new Soap();
}
{ i = 47;} //實例初始化
public String toString(){
if( s4 == null){
s4 = "joy"; //惰性初始化
}
return
"s1 = " + s1 + "\n" +
"s2 = " + s2 + "\n" +
"s3 = " + s3 + "\n" +
"s4 = " + s4 + "\n" +
"i = " + i + "\n" +
"toy = " + toy + "\n" +
"castille = " + castille;
}
public static void main(String[] args) {
Bath b = new Bath();
System.out.println(b);
}
}
七、構造器初始化
-
構造器的初始化,無法阻止自動初始化的進行,它將在構造器被調用之前發生
初始化順序:
1、變量定義的先后順序決定了初始化的順序。無論變量定義位于方法何處,它們仍然后在任何方法(包括構造器)被調用之前得到初始化
2、初始化的順序是先靜態對象,而后是非靜態對象對象的創建過程: 1、查找類路徑,定義 類.class 文件 2、載入 類.class 文件(這將創建一個Class對象),執行靜態初始化的所有動作。因此,靜態初始化只在Class對象首次加載的時候進行一次 3、用 new 類() 創建對象時,在堆(heap)內存上為對象分配足夠的存儲空間 4、這塊存儲空間空間會被 自動初始化 ,即將基本類型數據設置成默認值,引用類型數據設置成 null 5、執行所有定義的初始化動作 6、執行構造器
八、數組的初始化
- 定義一個數組
int[] a1;
編譯器不允許指定數組的大小,為了給數組創建相應的存儲空間,必須寫初始化表達式
將一個數組賦值給另一個數組,其實只是復制一個引用
數組元素中的基本數據類型值會自動化成空值