溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java關(guān)鍵字final的示例分析

發(fā)布時(shí)間:2021-05-28 09:36:54 來(lái)源:億速云 閱讀:148 作者:小新 欄目:開(kāi)發(fā)技術(shù)

小編給大家分享一下Java關(guān)鍵字final的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、常見(jiàn)問(wèn)題

  • 所有的final修飾的字段都是編譯期常量嗎?

  • 如何理解private所修飾的方法是隱式的final?

  • 說(shuō)說(shuō)final類型的類如何拓展?比如String是final類型,我們想寫(xiě)個(gè)MyString復(fù)用所有String中方法,同時(shí)增加一個(gè)新的toMyString()的方法,應(yīng)該如何做?

  • final方法可以被重載嗎?可以

  • 父類的final方法能不能夠被子類重寫(xiě)?不可以

  • 說(shuō)說(shuō)final域重排序規(guī)則?

  • 說(shuō)說(shuō)final的原理?

  • 使用 final 的限制條件和局限性?

二、final修飾類

當(dāng)某個(gè)類的整體定義為final時(shí),就表明了你不能打算繼承該類,而且也不允許別人這么做。即這個(gè)類是不能有子類的。
注意:final類中的所有方法都隱式為final,因?yàn)闊o(wú)法覆蓋他們,所以在final類中給任何方法添加final關(guān)鍵字是沒(méi)有任何意義的。

三、final修飾方法

類中所有private方法都隱式地指定為final的,由于無(wú)法取用private方法,所以也就不能覆蓋它。可以對(duì)private方法增添final關(guān)鍵字,但這樣做并沒(méi)有什么好處。

public class Base {
    private void test() {
    }
}

public class Son extends Base{
    public void test() {
    }
    public static void main(String[] args) {
        Son son = new Son();
        Base father = son;
        //father.test();
    }
}

Base和Son都有方法test(),但是這并不是一種覆蓋,因?yàn)閜rivate所修飾的方法是隱式的final,也就是無(wú)法被繼承,所以更不用說(shuō)是覆蓋了,在Son中的test()方法不過(guò)是屬于Son的新成員罷了,Son進(jìn)行向上轉(zhuǎn)型得到father,但是father.test()是不可執(zhí)行的,因?yàn)锽ase中的test方法是private的,無(wú)法被訪問(wèn)到。

四、final方法是可以被重載的

我們知道父類的final方法是不能夠被子類重寫(xiě)的,那么final方法可以被重載嗎? 答案是可以的,下面代碼是正確的。

public class FinalExampleParent {
    public final void test() {
    }

    public final void test(String str) {
    }
}

修飾參數(shù)
Java允許在參數(shù)列表中以聲明的方式將參數(shù)指明為final,這意味這你無(wú)法在方法中更改參數(shù)引用所指向的對(duì)象。這個(gè)特性主要用來(lái)向匿名內(nèi)部類傳遞數(shù)據(jù)。

五、修飾變量

public class Test {
    //編譯期常量
    final int i = 1;
    final static int J = 1;
    final int[] a = {1,2,3,4};
    //非編譯期常量
    Random r = new Random();
    final int k = r.nextInt();

    public static void main(String[] args) {

    }
}

k的值由隨機(jī)數(shù)對(duì)象決定,所以不是所有的final修飾的字段都是編譯期常量,只是k的值在被初始化后無(wú)法被更改。

六、static final

一個(gè)既是static又是final 的字段只占據(jù)一段不能改變的存儲(chǔ)空間,它必須在定義的時(shí)候進(jìn)行賦值,否則編譯器將不予通過(guò)。

public class finaltest
{
    //Random對(duì)象r
    static Random r = new Random();
    //生成隨機(jī)數(shù)k
    final int k = r.nextInt(10);
    //生成隨機(jī)數(shù)k2
    static final int k2 = r.nextInt(10);
    
    public static void main(String[] args) {
        
        finaltest t1 = new finaltest();
        
        System.out.println("k="+t1.k+" k2="+t1.k2);
        
        finaltest t2 = new finaltest();
        
        System.out.println("k="+t2.k+" k2="+t2.k2);
    }
}

k=2 k2=7
k=8 k2=7
我們可以發(fā)現(xiàn)對(duì)于不同的對(duì)象k的值是不同的,但是k2的值卻是相同的,這是為什么呢? 因?yàn)閟tatic關(guān)鍵字所修飾的字段并不屬于一個(gè)對(duì)象,而是屬于這個(gè)類的。也可簡(jiǎn)單的理解為static final所修飾的字段僅占據(jù)內(nèi)存的一個(gè)一份空間,一旦被初始化之后便不會(huì)被更改。

七、black final

Java允許生成空白final,也就是說(shuō)被聲明為final但又沒(méi)有給出定值的字段,但是必須在該字段被使用之前被賦值,這給予我們兩種選擇:

  • 在定義處進(jìn)行賦值(這不叫空白final)

  • 在構(gòu)造器中進(jìn)行賦值,保證了該值在被使用前賦值。

這增強(qiáng)了final的靈活性。

final int i1 = 1;

    final int i2;//空白final

    public finaltest() {
        i2 = 1;
    }
    public finaltest(int x) {
        this.i2 = x;
    }

可以看到i2的賦值更為靈活。但是請(qǐng)注意,如果字段由static和final修飾,僅能在定義處賦值,因?yàn)樵撟侄尾粚儆趯?duì)象,屬于這個(gè)類。

以上是“Java關(guān)鍵字final的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI