一.問題 隨著電腦革命的發展,“不安全”的編程方式已逐漸成為編程代價高昂的主因之一。 初始化和清理正是涉及安全的兩個問題。 二.java 解決方案 構造器:一種特殊的方法。java 中”初始化“和”創建“捆綁在一起,兩者不能分離。 垃圾回收器:釋放無用的對象。 三.方法重載 為什麼要在這裡講方法重 ...
一.問題
隨著電腦革命的發展,“不安全”的編程方式已逐漸成為編程代價高昂的主因之一。
初始化和清理正是涉及安全的兩個問題。
二.java 解決方案
構造器:一種特殊的方法。java 中”初始化“和”創建“捆綁在一起,兩者不能分離。
垃圾回收器:釋放無用的對象。
三.方法重載
為什麼要在這裡講方法重載?我覺得首先:構造器是一種特殊的方法,再一個,構造器除了預設構造器還有有參構造器。為了讓方法名稱相同而形式參數不同的構造器同時存在,就必須用到方法重載。
區分方法重載的判決條件
1.參數的數量是否相同
2.參數的類型是否相同
只要其中一條為否,則就是方法重載,必須記住重載的前提:方法名稱必須相同。
四.構造器中調用構造器
1.儘管可以用this調用一個構造器,但卻不能調用兩個。此外,必須將構造器調用置於最起始處,否則編譯錯誤。
2.除構造器之外,編譯器禁止在其他任何方法中調用構造器。
五.成員初始化途徑
1.所有變數在使用前都能得到恰當的初始化,類的基本類型預設為基本類型的預設值,局部變數必須由編程者指定初始值,在類中,一個對象引用不將其初始化,就會獲得特殊的null值。
2.編程者指定變數初始化值
3.通過構造器初始化變數值,但是自動初始化在構造器初始化之前完成。
六.變數初始化順序
變數定義的順序決定了初始化的順序,即使變數定義散步於方法定義之間。
七.靜態數據初始化
無論創建多少個對象,靜態數據都只占用一份存儲區域,static 關鍵字不能用於局部變數,因此只能作用於域。
八.非靜態實例初始化
代碼如下:
Class Mug{ Mug(int maker){ print("Mug("+maker+")"); } void f(int maker){ print("f("+maker+")"); } } public Class Mugs{ Mug mug1; Mug mug2; { mug1= new Mug(1); mug2= new Mug(2); print("mug1&mug2 initial"); } Mugs() { print("Mugs(int)"); } public static void main(String[] args) { print("Inside main()"); new Mugs(); print("new Mugs() completed"); new Mugs(1); print("new Mugs(1) completed"); } }
從輸出結果可以看出,實例初始化子句是在兩個構造器之前執行的。
九,對六七八的總結
1.首先初始化靜態的變數(第一次訪問.class文件時初始化,只初始化一次),然後初始化非靜態變數
2.非靜態變數會被創建對象時複製給預設值。
3.執行編程值為變數指定的初始值。
4.執行構造器。