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

Java中final關鍵字的使用與注意總結

 更新時間:2020年08月19日 16:30:30   作者:IBLiplus  
這篇文章主要給大家介紹了關于Java中final關鍵字的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Java具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

在java中可以將實例域定義為final。在構建對象是必須初始化這樣的值。必須確保在每個構造器執(zhí)行之后,這個域的值被設置,并且在后面的操作中不再對其修改。使用final聲明變量之后,這個值就不能修改,一般final類型的變量都被聲明為靜態(tài)變量,而且是公有類型的,它在內存中被放在一個特有的公共區(qū)域。

也就是說,在Java語法中規(guī)定,final修飾的成員變量必須有程序員顯式地指定初始值。

定義格式為: public  static  final  double pi = 3.1415926;

final修飾符大多應用于基本類型域,或不可變類的域(如果類中的每個方法都不會改變其對象,這種類成為不可變類。比如說Java中的String類就是一個不可變類。)

如果定義了兩個相同的變量,都是final類型的,這兩個相同的變量名有著不同的值,其實在內存中是開辟了兩個內存空間,之前定義的變量的值會被后來定義的變量的值覆蓋掉。原理是變量名指向后來定義的變量值的內存空間,之前定義的變量值會被Java虛擬機根據某種特定的算法在特定的時間處理掉。

在下面的代碼中詳細的介紹了final類型的變量如何進行定義和初始化:

public class FinalVariableText {
 //定義成員變量是指定默認值,合法
 final int a = 6;
 //下面變量將在構造器或初始化塊中分配初始值
 final String str;
 final int c ;
 final static double d;
 //既沒有指定默認值,也沒有在初始化塊、構造器中指定初始值
 //下面定義的ch實例變量是不合法的
 //final char ch;
 
 {
 //在初始化塊中只懂初始值,合法
 str ="hello" ;
 //定義a實例變量已經有初始值了,不能為a重新賦值。下面的語句是不正確的
 //a = 9;
 }
 
 //靜態(tài)初始化塊
 static {
 // d是靜態(tài)成員變量,必須在靜態(tài)初始化塊中為其指定初始值
 d = 5.6;
 
 }
 //構造器,可對 沒有設置初始值的成員變量設置初始值
 //構造器必須與類名相同,這一點注意!
 public FinalVariableText(){
 //如果在初始化塊中對str賦初值,在構造器中在為str重新賦值,是不合法的,程序會拋出錯誤。
 c = 5;
 }
 
 public void changeFinal() {
 //普通方法不能為final修飾的成員變量賦值
 //d = 1.3;
 //也不能在普通方法中為沒有設置初始值的final類型的變量賦初值
 //ch = 'ch';
 
 }
 
 public static void main(String[] args) {
  
 FinalVariableText ff = new FinalVariableText();
 System.out.println(ff.a);
 System.out.println(ff.c);
 System.out.println(ff.str);
 System.out.println(ff.d); 
 }

結果:
6
5
hello
5.6

注意:

如果打算在構造器、初始化塊中對final類型的成員變量進行初始化,則不要在初始化之前訪問成員變量的值,否則會引發(fā)程序報錯。

final也存在局部變量的情況

系統(tǒng)不會對局部變量進行初始化,局部變量必須由程序員顯式的進行初始化,因此使用final修飾局部變量的時候,既可以在定義是設定默認值,也可以不指定默認值。如果在定義是沒有進行設定默認值,則可以在后面的代碼中對該final變量賦初值,但只能一次,不可以重復賦值。當然如果在定義變量的時候就已經指定默認值,在后面的代碼中就沒有必要也不允許對該變量在進行賦值操作。

 public void text(final int a) {
 //不能對fianl修飾的形參進行賦值操作
 //a = 5; 該語句是不合法的
 }
 public static void main(String[] args) {
  //定義final局部變量時,指定初始值,則該變量再無法進行賦值了
 final String str = "str";
 //下面的語句會報錯,不合法
 //str = "Java";
 //定義final變量沒有指定默認值,則可以被賦值一次
 final int d;
 d = 5;
 //再對d進行新的賦值,不合法
 // d = 8;
 
 }

Final修飾基本類型變量和引用類型的變量的區(qū)別

Final修飾基本類型變量上面已經講述的很清楚了,那引用類型的變量會有什么不同呢?對于引用類型的變量而言,它僅僅是保存了一個引用關系,final只保證這個引用類型變量所引用的地址不會改變,即一直引用同一個對象,但這個對象完全可以發(fā)生改變。下面通過代碼來驗證一下:

class Person1{
 
 private int age;
 //有一個參數的構造函數
 public Person1(int age) {
 this.age = age; 
 }
 public int getAge() {
 return age;
 }
 public void setAge(int age) {
 this.age = age;
 }
}
 
public class FinalReferenceText {
 
 public static void main(String[] args) {
  
  final int [] arr = {5,6,12,9};
  System.out.println(Arrays.toString(arr));
  Arrays.sort(arr);
  System.out.println(Arrays.toString(arr));
  arr[2] = -8;
  System.out.println(Arrays.toString(arr));
  //下面對arr重新賦值,非法
  //arr = null;
  //final 修飾Person變量,p是一個引用變量
  final Person1 p = new Person1(45);
  //改變Person對象的實例變量,合法
  p.setAge(55);
  System.out.println(p.getAge());
  //下面對p重新賦值,非法
  //p = null;
 }
 
}

結果:
[5, 6, 12, 9]
[5, 6, 9, 12]
[5, 6, -8, 12]
55

final方法

Final修飾的方法不可被重寫,如果處于某種原因,不希望子類重寫父類的某個方法,則可以使用final關鍵字修飾該方法。

如果父類中的方法的是公有的,則子類中不能有一個一樣方法名,一樣參數的方法,但如果父類中的方法是私有的,那么子類中完全可以寫一個一樣的方法。

對于private類型的方法,由于其只能在當前類中可見,其子類無法訪問到該方法,所以子類無法重寫該方法,那么,如果子類中存在一個與父類private方法有相同方法名,一樣的參數列表,相同的返回值的方法,也不是方法的重寫,只是重新定義了一個新的方法。因此,final修飾一個private方法,依然可以在其子類中定義和父類private類型一樣的方法,不會有程序錯誤。

public class PrivateFinalText{
 
 //如果將訪問修飾符改成public,則其子類中的方法定義在程序編譯時會報錯
 private final void text();
 
}
 
class Sub extends PrivateFinalText{
 //下面的方法完全沒有問題
 public void text();
}

以上是我目前對Java中final關鍵字的總結,稍后會有補充?。?!

總結

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

相關文章

  • Java中的幾種讀取properties配置文件的方式

    Java中的幾種讀取properties配置文件的方式

    這篇文章主要介紹了Java中的幾種讀取properties配置文件的方式,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • java使用任務架構執(zhí)行任務調度示例

    java使用任務架構執(zhí)行任務調度示例

    在Java 5.0之前啟動一個任務是通過調用Thread類的start()方法來實現的,5.0里提供了一個新的任務執(zhí)行架構使你可以輕松地調度和控制任務的執(zhí)行,并且可以建立一個類似數據庫連接池的線程池來執(zhí)行任務,下面看一個示例
    2014-01-01
  • 自定義注解實現Spring容器注入Bean方式(類似于mybatis的@MapperScans)

    自定義注解實現Spring容器注入Bean方式(類似于mybatis的@MapperScans)

    本文介紹了如何通過自定義注解@MyService和@MyServiceScans在SpringBoot項目中自動將指定包下的類注入Spring容器,詳細解釋了創(chuàng)建自定義注解、定義包掃描器ClassPathBeanDefinitionScanner的作用與實現
    2024-09-09
  • Springboot?多租戶SaaS搭建方案

    Springboot?多租戶SaaS搭建方案

    這篇文章主要介紹了Springboot?多租戶SaaS方案,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • Struts 2中的constant配置詳解

    Struts 2中的constant配置詳解

    通過對這些屬性的配置,可以改變Struts 2 框架的一些默認行為,這些配置可以在struts.xml文件中完成,也可以在struts.properties文件中完成
    2016-09-09
  • Java通用Mapper UUID簡單示例

    Java通用Mapper UUID簡單示例

    今天小編就為大家分享一篇關于Java通用Mapper UUID簡單示例,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • Spring Web MVC和Hibernate的集成配置詳解

    Spring Web MVC和Hibernate的集成配置詳解

    這篇文章主要介紹了Spring Web MVC和Hibernate的集成配置詳解,具有一定借鑒價值,需要的朋友可以參考下
    2017-12-12
  • java IP地址網段計算的示例代碼

    java IP地址網段計算的示例代碼

    這篇文章主要介紹了java IP地址網段計算的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • IDEA運行SSM項目的超詳細圖解教程

    IDEA運行SSM項目的超詳細圖解教程

    SSM項目部署其實很簡單,下面這篇文章主要給大家介紹了關于IDEA運行SSM項目的超詳細圖解教程,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-10-10
  • Java異常處理機制深入理解

    Java異常處理機制深入理解

    如果某個方法不能按照正常的途徑完成任務,就可以通過另一種路徑退出方法。在這種情況下會拋出一個封裝了錯誤信息的對象。此時,這個方法會立刻退出同時不返回任何值。另外,調用這個方法的其他代碼也無法繼續(xù)執(zhí)行,異常處理機制會將代碼執(zhí)行交給異常處理器
    2022-01-01

最新評論