亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java中finalize()詳解及用法

 更新時間:2017年03月03日 14:25:57   投稿:lqh  
這篇文章主要介紹了Java中finalize()詳解及用法的相關資料,final是Java的關鍵字,它所表示的是“這部分是無法修改的”,需要的朋友可以參考下

 Java中finalize()詳解

  在程序設計中,我們有時可能希望某些數據是不能夠改變的,這個時候final就有用武之地了。final是Java的關鍵字,它所表示的是“這部分是無法修改的”。不想被改變的原因有兩個:效率、設計。使用到final的有三種情況:數據、方法、類。

       一、 final數據

       有時候數據的恒定不變是很有用的,它能夠減輕系統(tǒng)運行時的負擔。對于這些恒定不變的數據我可以叫做“常量”?!俺A俊敝饕獞门c以下兩個地方:

       1、編譯期常量,永遠不可改變。

       2、運行期初始化時,我們希望它不會被改變。

       對于編譯期常量,它在類加載的過程就已經完成了初始化,所以當類加載完成后是不可更改的,編譯期可以將它代入到任何用到它的計算式中,也就是說可以在編譯期執(zhí)行計算式。當然對于編譯期常量,只能使用基本類型,而且必須要在定義時進行初始化。

       有些變量,我們希望它可以根據對象的不同而表現(xiàn)不同,但同時又不希望它被改變,這個時候我們就可以使用運行期常量。對于運行期常量,它既可是基本數據類型,也可是引用數據類型?;緮祿愋筒豢勺兊氖瞧鋬热荩脭祿愋筒豢勺兊氖瞧湟?,引用所指定的對象內容是可變的。

public class Person { 
  private String name; 
 
  Person(String name){ 
    this.name = name; 
  } 
   
  public String getName() { 
    return name; 
  } 
 
  public void setName(String name) { 
    this.name = name; 
  } 
} 
 
public class FinalTest { 
  private final String final_01 = "chenssy";  //編譯期常量,必須要進行初始化,且不可更改 
  private final String final_02;        //構造器常量,在實例化一個對象時被初始化 
   
  private static Random random = new Random(); 
  private final int final_03 = random.nextInt(50);  //使用隨機數來進行初始化 
   
  //引用 
  public final Person final_04 = new Person("chen_ssy");  //final指向引用數據類型 
   
  FinalTest(String final_02){ 
    this.final_02 = final_02; 
  } 
   
  public String toString(){ 
    return "final_01 = " + final_01 +"  final_02 = " + final_02 + "  final_03 = " + final_03 + 
        "  final_04 = " + final_04.getName(); 
  } 
   
  public static void main(String[] args) { 
    System.out.println("------------第一次創(chuàng)建對象------------"); 
    FinalTest final1 = new FinalTest("cm"); 
    System.out.println(final1); 
    System.out.println("------------第二次創(chuàng)建對象------------"); 
    FinalTest final2 = new FinalTest("zj"); 
    System.out.println(final2); 
    System.out.println("------------修改引用對象--------------"); 
    final2.final_04.setName("chenssy"); 
    System.out.println(final2); 
  } 
} 
 
------------------ 
Output: 
------------第一次創(chuàng)建對象------------ 
final_01 = chenssy  final_02 = cm  final_03 = 34  final_04 = chen_ssy 
------------第二次創(chuàng)建對象------------ 
final_01 = chenssy  final_02 = zj  final_03 = 46  final_04 = chen_ssy 
------------修改引用對象-------------- 
final_01 = chenssy  final_02 = zj  final_03 = 46  final_04 = chenssy 

       這里只闡述一點就是:不要以為某些數據是final就可以在編譯期知道其值,通過final_03我們就知道了,在這里是使用隨機數其進行初始化,他要在運行期才能知道其值。

       二、 final方法

       所有被final標注的方法都是不能被繼承、更改的,所以對于final方法使用的第一個原因就是方法鎖定,以防止任何子類來對它的修改。至于第二個原因就是效率問題,鄙人對這個效率問題理解的不是很清楚,在網上摘抄這段話:在java的早期實現(xiàn)中,如果將一個方法指明為final,就是同意編譯器將針對該方法的所有調用都轉為內嵌調用。當編譯器發(fā)現(xiàn)一個final方法調用命令時,它會根據自己的謹慎判斷,跳過插入程序代碼這種正常的調用方式而執(zhí)行方法調用機制(將參數壓入棧,跳至方法代碼處執(zhí)行,然后跳回并清理棧中的參數,處理返回值),并且以方法體中的實際代碼的副本來代替方法調用。這將消除方法調用的開銷。當然,如果一個方法很大,你的程序代碼會膨脹,因而可能看不到內嵌所帶來的性能上的提高,因為所帶來的性能會花費于方法內的時間量而被縮減。

對這段話理解我不是很懂就照搬了,那位java牛人可以解釋解釋下??!

      父類的final方法是不能被子類所覆蓋的,也就是說子類是不能夠存在和父類一模一樣的方法的。

public class Custom extends Person{ 
  public void method1(){ 
    System.out.println("Person's method1...."); 
  } 
   
//  Cannot override the final method from person:子類不能覆蓋父類的final方法 
//  public void method2(){ 
//    System.out.println("Person's method2..."); 
//  } 
} 

      三、 final類

       如果某個類用final修改,表明該類是最終類,它不希望也不允許其他來繼承它。在程序設計中處于安全或者其他原因,我們不允許該類存在任何變化,也不希望它有子類,這個時候就可以使用final來修飾該類了。
對于final修飾的類來說,它的成員變量可以為final,也可以為非final。如果定義為final,那么final數據的規(guī)則同樣適合它。而它的方法則會自動的加上final,因為final類是無法被繼承,所以這個是默認的。

       四、 final參數

       在實際應用中,我們除了可以用final修飾成員變量、成員方法、類,還可以修飾參數、若某個參數被final修飾了,則代表了該參數是不可改變的。

       如果在方法中我們修改了該參數,則編譯器會提示你:The final local variable i cannot be assigned. It must be blank and not using a compound assignment。

public class Custom { 
  public void test(final int i){ 
   //i++;   ---final參數不可改變 
    System.out.println(i); 
  } 
   
  public void test(final Person p){ 
   //p = new Person();  --final參數不可變 
   p.setName("chenssy"); 
  } 
} 

       同final修飾參數在內部類中是非常有用的,在匿名內部類中,為了保持參數的一致性,若所在的方法的形參需要被內部類里面使用時,該形參必須為final。

       五、final與static

       final和static在一起使用就會發(fā)生神奇的化學反應,他們同時使用時即可修飾成員變量,也可修飾成員方法。

       對于成員變量,該變量一旦賦值就不能改變,我們稱它為“全局常量”。可以通過類名直接訪問。

       對于成員方法,則是不可繼承和改變??梢酝ㄟ^類名直接訪問。

 感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

  • java arrayList遍歷的四種方法及Java中ArrayList類的用法

    java arrayList遍歷的四種方法及Java中ArrayList類的用法

    arraylist是動態(tài)數組,它具有三個好處分別是:動態(tài)的增加和減少元素 、實現(xiàn)了ICollection和IList接口、靈活的設置數組的大小,本文給大家介紹java arraylist遍歷及Java arraylist 用法,感興趣的朋友一起學習吧
    2015-11-11
  • Java微服務Nacos Config配置中心超詳細講解

    Java微服務Nacos Config配置中心超詳細講解

    配置文件相對分散。在一個微服務架構下,配置文件會隨著微服務的增多變的越來越多,而且分散 在各個微服務中,不好統(tǒng)一配置和管理。每一個環(huán)境所使用的配置理論上都是不同的,一旦需要修改,就需要我們去各個微服務下手動維護
    2023-02-02
  • Java讀取txt文件中的數據賦給String變量方法

    Java讀取txt文件中的數據賦給String變量方法

    今天小編就為大家分享一篇Java讀取txt文件中的數據賦給String變量方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • SpringCloud Gateway鑒權和跨域解決方案

    SpringCloud Gateway鑒權和跨域解決方案

    網關是介于客戶端和服務器端之間的中間層,所有的外部請求都會先經過 網關這一層,也就是說,API 的實現(xiàn)方面更多的考慮業(yè)務邏輯,而安全、性能、監(jiān)控可以交由 網關來做,這樣既提高業(yè)務靈活性又不缺安全性,本文給大家介紹SpringCloud Gateway鑒權和跨域解決方案,一起看看吧
    2023-11-11
  • java在linux系統(tǒng)下開機啟動無法使用sudo命令的原因及解決辦法

    java在linux系統(tǒng)下開機啟動無法使用sudo命令的原因及解決辦法

    每次開機自動啟動的java進程,頁面上的關機按鈕都無法實現(xiàn)關機功能,但是此時如果以chb賬號通過ssh登錄該服務器,手動殺掉tomcat進程,然后再重新啟動tomcat,頁面上的關機按鈕就有效了
    2013-08-08
  • Spring Boot + Mybatis 實現(xiàn)動態(tài)數據源案例分析

    Spring Boot + Mybatis 實現(xiàn)動態(tài)數據源案例分析

    這篇文章主要介紹了Spring Boot + Mybatis 實現(xiàn)動態(tài)數據源,需要的朋友可以參考下
    2018-11-11
  • Java?switch?case語句舉例詳解

    Java?switch?case語句舉例詳解

    這篇文章主要給大家介紹了關于Java?switch?case語句舉例詳解的相關資料,switch case語句是一種流程控制語句,用于根據不同的條件執(zhí)行不同的代碼塊,需要的朋友可以參考下
    2023-10-10
  • SpringCloud中使用Sentinel實現(xiàn)限流的實戰(zhàn)

    SpringCloud中使用Sentinel實現(xiàn)限流的實戰(zhàn)

    限流在很多地方都可以使用的到,本篇博客將介紹如何使用SpringCloud中使用Sentinel實現(xiàn)限流,從而達到服務降級的目的,感興趣的可以了解一下
    2022-01-01
  • Java中的運算符有哪些詳解

    Java中的運算符有哪些詳解

    這篇文章主要給大家介紹了關于Java中運算符有哪些的相關資料,包括算術運算符、關系運算符、邏輯運算符、位運算符、增量運算符和自增/自減運算符,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-10-10
  • Java中的同步非阻塞IO模型詳解

    Java中的同步非阻塞IO模型詳解

    這篇文章主要介紹了Java中的同步非阻塞IO模型詳解,同步非阻塞IO模型,我們能夠知道,用戶線程一直發(fā)送請求,內核一直都能都夠返回 ,直到內核完成準備數據、數據拷貝的工作,并且返回成功的指示,在此過程中用戶線程不是阻塞的狀態(tài),需要的朋友可以參考下
    2024-01-01

最新評論