欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中關鍵字final finally finalize的區(qū)別介紹

 更新時間:2022年04月25日 10:08:15   作者:紙照片  
這篇文章主要給大家分享的是 Java中final,finally,finalize 到底有什么區(qū)別,文章圍繞final,finally,finalize的相關資料展開詳細內(nèi)容,具有一定的參考的價值,需要的朋友可以參考一下

這三個除了長得像以外,好像沒什么聯(lián)系

1. final

final意為“最后的”,它是Java中的一個關鍵字。

final可以修飾屬性、方法、類。

1.1 final修飾屬性

從final的含義就不難理解用final修飾內(nèi)容的用意。final修飾屬性,就表示這個屬性是“最終的”,也就是不可更改的,換成我們熟悉的名詞,也就是“常量”。

private final double PI = 3.1415926;   //被final修飾的屬性常常用大寫表示,全部大寫在idea的快捷鍵是ctrl+shift+u

此時如果再想修改這個值,就會報錯。

final修飾的屬性可以通過多種方式進行初始化,比如顯式初始化、代碼塊初始化、構造方法初始化等等。

public class Test {
    private final int WIDTH = 10;   //顯示初始化
    private final int HEIGHT;
    private final int LEFT;
    {
        HEIGHT = 10;   //代碼塊初始化
    }
    public Test(){
        LEFT = 10;  //構造方法初始化
    }
    public Test(int n){
        LEFT = n;   //構造方法初始化
    }
}

final修飾屬性經(jīng)常和static一起使用,表示全局常量 。

另外,final還可以修飾局部變量

public void test(final int NUMBER){
}
public void test(int number){
    final int NUM = number;
}

上文提到final修飾屬性的多種初始化方法,這里注意一點,切記不要使用普通方法去初始化,當然這種方式都不會編譯通過。因為final引用的屬性在對象出現(xiàn)前就已經(jīng)存在了,調(diào)用方法賦值就太晚了。

1.2 final修飾方法

final修飾方法表示此方法不可重寫。套用含義上的理解,也就是“最終的方法”,也就是不可被修改的方法。

比如寫一個父類

class ParentClass{
    public final void finalMethod(){  
    }
}

嘗試在子類中重寫這個方法,就會報錯。

1.3 final修飾類

final修飾類,套用含義上的理解,“最終的類”意為不可修改的類,表示該類不可被繼承,因為繼承就可以重寫方法、擴展功能,是對現(xiàn)有類的修改。

聲明一個final的類

final class ParentClass{
}

嘗試去繼承這個類,就會報錯

2. finally

finally用于異常處理,try-catch-finally,finally表示最終會執(zhí)行的功能塊。finally包裹的代碼塊一定會執(zhí)行。(注意這個“一定會執(zhí)行”,后文有坑)

try{
    //可能出現(xiàn)異常的代碼
}
catch(異常類型1 變量名1){
    //處理異常的方式1
}
catch(異常類型2 變量名2){
    //處理異常的方式2
}
finally{
    //一定會執(zhí)行的代碼
}

舉一個例子

@Test
public void test(){
    try{
        int a = 10;
        int b = 0;
        System.out.println(a/b);
    }
    catch (ArithmeticException e){
        System.out.println("處理方式1");
    }
    catch (Exception e){
        System.out.println("處理方式2");
    }
    finally {
        System.out.println("執(zhí)行finally");
    }
}

執(zhí)行結果:

注意以下三點:

  • finally是可選的,在try-catch結構中不使用finally沒有任何問題
  • finally聲明的代碼是一定會執(zhí)行的
  • 像數(shù)據(jù)庫連接、輸入輸出流、網(wǎng)絡Socket… JVM是不能自動回收的,所以常常在可能存在異常的代碼中手動在finally釋放掉這些資源

擴展-finally和return誰會先執(zhí)行?

上文多次提到“finally聲明的代碼是一定會執(zhí)行的”,那么在try或者catch中出現(xiàn)了return,那么誰會先執(zhí)行?

執(zhí)行以下代碼,會輸出什么?

private int finallyTest(){
    try{
        int a = 10;
        int b = 0;
        System.out.println(a/b);
        return 1;
    }
    catch (Exception e){
        return 2;
    }
    finally {
        System.out.println("執(zhí)行finally");
    }
}

調(diào)用一下

@Test
public void test(){
    int num = finallyTest();
    System.out.println(num);
}

結果如下圖,也就是即使在catch中有return語句,也要等待finally聲明的代碼執(zhí)行完再return出去。

3. finalize

finalize翻譯為“使結束”,它是一個方法,是每個類默認存在的方法。

打開Object類的源碼,就可以找到finalize()方法

finalize()方法用于GC回收,finalize是本文最難理解的概念,要真正理解finalize()方法,就要深入理解GC回收機制,而本文的側重點并不在于解釋GC回收機制,所以只會簡單地描述一下finalize()方法的使用場景,讀者如果感興趣,請自行查找相關的文章。

在Java的內(nèi)存管理中,使用可達性分析算法來判斷對象是否存活,基本思路是通過一系列稱為“GC Roots”的跟對象作為起始節(jié)點,根據(jù)引用關系向下搜索,如果某些對象到GC Roots之間沒有任何引用關系,則證明此對象是不能被再使用的,就有可能去回收這一塊內(nèi)存了。下圖中,雖然object5、object6、object7之間有引用關系,但是到GC Roots沒有任何途徑,則這些對象仍在回收的范圍內(nèi)。

生存還是死亡?

即使經(jīng)過可達性分析算法判定為不可達的對象,也不是非要回收不可,要真正回收一個內(nèi)存空間,至少需要兩次的不可達判定。經(jīng)過第一次不可達判定,隨后要進行一個篩選,篩選的條件是該對象是否有必要執(zhí)行finalize()方法。假如待回收的對象沒有重寫finalize()方法,或者finalize()方法被JVM調(diào)用過(每個對象的finalize()方法只能被JVM調(diào)用一次),這兩種情況都會被虛擬機認為是“沒有必要執(zhí)行finalize()方法”,那么在經(jīng)過幾輪不可達標記后,該對象被真正地回收掉。

如果該對象被認定為“有必要執(zhí)行finalize()方法”,則稍后會被低調(diào)度優(yōu)先級的線程去執(zhí)行finalize()方法,而重寫的finalize()方法有可能完成一次對象的“自救”,比如將this賦給某個屬性,那么在后續(xù)標記時會被判定為“可達”,那么JVM就不會回收這個對象。

盡管finalize()方法有著特殊的使用場景,但是永遠也不要顯式調(diào)用某個對象的finalize()方法,應該交給GC回收機制調(diào)用。

到此這篇關于Java中關鍵字final finally finalize的區(qū)別介紹的文章就介紹到這了,更多相關Java關鍵字final finally finalize內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Spring Boot使用Value注解給靜態(tài)變量賦值的方法

    Spring Boot使用Value注解給靜態(tài)變量賦值的方法

    這篇文章主要介紹了Spring Boot使用Value注解給靜態(tài)變量賦值的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • Java實現(xiàn)滑動驗證碼的示例代碼

    Java實現(xiàn)滑動驗證碼的示例代碼

    這篇文章主要介紹了Java實現(xiàn)滑動驗證碼的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Java多線程和并發(fā)基礎面試題(問答形式)

    Java多線程和并發(fā)基礎面試題(問答形式)

    多線程和并發(fā)問題是Java技術面試中面試官比較喜歡問的問題之一。在這里,從面試的角度列出了大部分重要的問題,感興趣的小伙伴們可以參考一下
    2016-06-06
  • 從0到1學SpringCloud之SpringCloud?gateway網(wǎng)關路由配置示例詳解

    從0到1學SpringCloud之SpringCloud?gateway網(wǎng)關路由配置示例詳解

    Spring?Cloud?Gateway的目標提供統(tǒng)一的路由方式且基于Filter?鏈的方式提供了網(wǎng)關基本的功能,?例如:安全、監(jiān)控、指標和限流?,這篇文章主要介紹了從0到1學SpringCloud之SpringCloud?gateway網(wǎng)關路由配置示例詳解,需要的朋友可以參考下
    2023-04-04
  • Java深入淺出掌握SpringBoot之MVC自動配置原理篇

    Java深入淺出掌握SpringBoot之MVC自動配置原理篇

    在進行項目編寫前,我們還需要知道一個東西,就是SpringBoot對我們的SpringMVC還做了哪些配置,包括如何擴展,如何定制,只有把這些都搞清楚了,我們在之后使用才會更加得心應手
    2021-10-10
  • SpringBoot結果封裝和異常攔截的實現(xiàn)示例

    SpringBoot結果封裝和異常攔截的實現(xiàn)示例

    SpringBoot 項目中,我們通常需要將結果數(shù)據(jù)封裝成特定的格式,以方便客戶端進行處理,本文主要介紹了SpringBoot?優(yōu)雅的結果封裝和異常攔截,感興趣的可以了解一下
    2023-08-08
  • java使用smortupload上傳和下載文件

    java使用smortupload上傳和下載文件

    這篇文章主要介紹了java使用smortupload上傳和下載文件實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • spring-cloud-gateway動態(tài)路由的實現(xiàn)方法

    spring-cloud-gateway動態(tài)路由的實現(xiàn)方法

    這篇文章主要介紹了spring-cloud-gateway動態(tài)路由的實現(xiàn)方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • Java的springcloud Sentinel是什么你知道嗎

    Java的springcloud Sentinel是什么你知道嗎

    這篇文章主要介紹了Java之springcloud Sentinel案例講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • JVM如何處理異常深入詳解

    JVM如何處理異常深入詳解

    異常處理的兩大元素:拋出異常、捕獲異常,非正常處理的兩個方法。下面這篇文章主要給大家介紹了關于JVM如何處理異常的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2019-01-01

最新評論