深入剖析final關鍵字的含義

public class Test2
{
	private final int a;
	private String name;

	public Test2()
	{
		a = 2;
	}

	public Test2(String name)
	{
		this.name = name;
	}
}

上面的代碼編譯不通過,初始化對象的時候這二個構造方法不知道到底會調用哪一個,但是對final類型的成員變量必須進行初始化,即使是等於0,也必須對final類型的變量寫明=0.

可以有二種方式來初始化final類型的成員變量:

1.聲明的時候直接賦值。

2.在構造方法中完成,如果一個類有多個構造方法要保證所有的構造方法都對該final成員變量有初始化。

如果將private final int a;   修改成private static  final int a;  則必須在定義聲明變量的時候給值,如:private static final int a=0;


<pre name="code" class="java">public class Test2
{
	public static void main(String[] args)
	{
		try
		{
			return;
		}
		catch (Exception e)
		{
			System.out.println("exception!");
		}
                finally
		{
			System.out.println("fianlly!");
		}
	}
}



上面代碼打印出:fianlly!

如果要使代碼不打印上面的fianlly!  可以不使用return,使用:System.exit(0);


<pre name="code" class="java"><pre name="code" class="java">interface I
{
}

public class Test2
{
	public static void main(String[] args)
	{
		I[] i = new I[2];
		I i = new I();
	}
}





上面的代碼中第一句代碼是正確的,我們知道非基本數據類型的數組保存的對象的引用,數組中每個元素指向實際生成了具體對象的首地址;如:i[0]=new 一個I接口的實現類。第二句代碼是錯誤的,因爲無法生成一個抽象的類。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章