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

Java中final關(guān)鍵字的使用與注意總結(jié)

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

前言

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

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

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

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

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

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

public class FinalVariableText {
 //定義成員變量是指定默認(rèn)值,合法
 final int a = 6;
 //下面變量將在構(gòu)造器或初始化塊中分配初始值
 final String str;
 final int c ;
 final static double d;
 //既沒有指定默認(rèn)值,也沒有在初始化塊、構(gòu)造器中指定初始值
 //下面定義的ch實(shí)例變量是不合法的
 //final char ch;
 
 {
 //在初始化塊中只懂初始值,合法
 str ="hello" ;
 //定義a實(shí)例變量已經(jīng)有初始值了,不能為a重新賦值。下面的語句是不正確的
 //a = 9;
 }
 
 //靜態(tài)初始化塊
 static {
 // d是靜態(tài)成員變量,必須在靜態(tài)初始化塊中為其指定初始值
 d = 5.6;
 
 }
 //構(gòu)造器,可對 沒有設(shè)置初始值的成員變量設(shè)置初始值
 //構(gòu)造器必須與類名相同,這一點(diǎn)注意!
 public FinalVariableText(){
 //如果在初始化塊中對str賦初值,在構(gòu)造器中在為str重新賦值,是不合法的,程序會(huì)拋出錯(cuò)誤。
 c = 5;
 }
 
 public void changeFinal() {
 //普通方法不能為final修飾的成員變量賦值
 //d = 1.3;
 //也不能在普通方法中為沒有設(shè)置初始值的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); 
 }

結(jié)果:
6
5
hello
5.6

注意:

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

final也存在局部變量的情況

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

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

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

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

class Person1{
 
 private int age;
 //有一個(gè)參數(shù)的構(gòu)造函數(shù)
 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是一個(gè)引用變量
  final Person1 p = new Person1(45);
  //改變Person對象的實(shí)例變量,合法
  p.setAge(55);
  System.out.println(p.getAge());
  //下面對p重新賦值,非法
  //p = null;
 }
 
}

結(jié)果:
[5, 6, 12, 9]
[5, 6, 9, 12]
[5, 6, -8, 12]
55

final方法

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

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

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

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

以上是我目前對Java中final關(guān)鍵字的總結(jié),稍后會(huì)有補(bǔ)充!??!

總結(jié)

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

相關(guān)文章

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

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

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

    java使用任務(wù)架構(gòu)執(zhí)行任務(wù)調(diào)度示例

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

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

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

    Springboot?多租戶SaaS搭建方案

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

    Struts 2中的constant配置詳解

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

    Java通用Mapper UUID簡單示例

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

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

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

    java IP地址網(wǎng)段計(jì)算的示例代碼

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

    IDEA運(yùn)行SSM項(xiàng)目的超詳細(xì)圖解教程

    SSM項(xiàng)目部署其實(shí)很簡單,下面這篇文章主要給大家介紹了關(guān)于IDEA運(yùn)行SSM項(xiàng)目的超詳細(xì)圖解教程,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • Java異常處理機(jī)制深入理解

    Java異常處理機(jī)制深入理解

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

最新評論