學(xué)習(xí)Java的static與final關(guān)鍵字
static:(靜態(tài)修飾符)面向?qū)ο笾衧tatic修飾的內(nèi)容是隸屬于類(lèi),而不是直接隸屬于對(duì)象的,所以static修飾的成員變量一般稱(chēng)作類(lèi)成員變量,而static修飾的方法一般稱(chēng)作類(lèi)方法。
分類(lèi):
1、static變量,也叫作靜態(tài)變量或者類(lèi)變量。另一種是沒(méi)有被static修飾的變量,叫實(shí)例變量。
2、static方法,也叫作靜態(tài)方法或者類(lèi)方法,靜態(tài)方法中不能定義靜態(tài)變量,實(shí)例方法也不能。
3、static代碼塊,靜態(tài)塊中,可以訪問(wèn)靜態(tài)變量,調(diào)用靜態(tài)方法。
注意事項(xiàng):
1、static不依附于任何對(duì)象,就沒(méi)有this方法。
2、static方法不可以調(diào)用非static方法,但非static方法可以調(diào)用static方法。
3、被static修飾的方法或者變量不需要依賴(lài)于對(duì)象來(lái)進(jìn)行訪問(wèn),只要類(lèi)被加載了,就可以通過(guò)類(lèi)名去進(jìn)行訪問(wèn)。
4、static方法不能被重寫(xiě),當(dāng)子類(lèi)與父類(lèi)中同時(shí)存在一樣的static方法時(shí),默認(rèn)調(diào)用的是父類(lèi)的靜態(tài)方法,子類(lèi)的靜態(tài)方法就被隱藏了。
5、static塊一般用于初始化類(lèi)中的靜態(tài)變量。在先執(zhí)行static修飾的內(nèi)容基礎(chǔ)上,遵循先定義先執(zhí)行的原則。
6、如果變量或方法經(jīng)常被調(diào)用的話,就使用static修飾。否則少用,避免造成內(nèi)存泄漏。
靜態(tài)變量的代碼例子:
public class Test{
static int a=1; //靜態(tài)變量
int b=2; //實(shí)例變量
public static void main(String[] args){
System.out.println(Test.a); //System.out.print(a);
System.out.println(b); //直接輸出變量b會(huì)報(bào)錯(cuò)
Test t=new Test(); //創(chuàng)建實(shí)例對(duì)象
System.out.println(t.b); //對(duì)象調(diào)用變量
}
}
靜態(tài)方法的代碼例子:
public class Test{
static int a=1; //靜態(tài)變量
int b=2; //實(shí)例變量
static void A(){ //靜態(tài)方法
B(); //報(bào)錯(cuò),靜態(tài)方法不可以調(diào)用非靜態(tài)方法
System.out.println(Test.a); //System.out.print(a);
}
void B(){ //非靜態(tài)方法
Test.A(); //A();非靜態(tài)方法可以調(diào)用靜態(tài)方法
System.out.println(b);
System.out.println(Test.a); //System.out.print(a);
}
public static void main(String[] args){
Test.A(); //A();
B(); //報(bào)錯(cuò),非靜態(tài)方法需要通過(guò)實(shí)例對(duì)象進(jìn)行調(diào)用
Test t=new Test();
t.B();
}
}
/*
* 是否能被重寫(xiě)
*/
class StaticSon extends Test{ //子類(lèi)繼承父類(lèi)
void A(){ //報(bào)錯(cuò),父類(lèi)的靜態(tài)方法不能被重寫(xiě)
/*......*/
}
static void A(){ //這是子類(lèi)的靜態(tài)方法,嚴(yán)格來(lái)說(shuō)并不是重寫(xiě)父類(lèi)的靜態(tài)方法
}
}
靜態(tài)塊的代碼例子:
public class Test{
int c=3;
static int a=1;
static int b=2;
static{
a=10;
b=20;
c=30; //報(bào)錯(cuò),靜態(tài)塊里的變量必須是靜態(tài)變量
System.out.println(a+b);
}
public static void main(String[] args){
Test t=new Test();
System.out.println(t.c); //先執(zhí)行靜態(tài)變量,再執(zhí)行實(shí)例變量
}
}
final:理解為不可變的。
注意事項(xiàng):
1、final與static經(jīng)常放在一起使用。
2、final修飾的變量,只能進(jìn)行一次賦值操作。
3、final方法不能被重寫(xiě),但可以被重載。
4、final類(lèi)不能被繼承。
5、final和abstract這兩個(gè)關(guān)鍵字是相反的,不可能同時(shí)修飾類(lèi)。因?yàn)閒inal不能被重寫(xiě),而abstract又必須重寫(xiě)。
6、final關(guān)鍵字不同于finally關(guān)鍵字,后者用于異常處理。
7、大多數(shù)情況下,并不用final來(lái)修飾方法和類(lèi),因?yàn)槠淇赏卣剐圆缓谩?/p>
8、final在一定的環(huán)境下使用,可以提高程序的運(yùn)行性能,優(yōu)化程序的結(jié)構(gòu)。
final變量與final類(lèi)的代碼例子:
public final class Test{
final static int a=1;
static {
a=10; //報(bào)錯(cuò),只能進(jìn)行一次賦值操作
}
}
class FinalSon extends Test{ //報(bào)錯(cuò),final類(lèi)不能被繼承
}
final方法的代碼例子:
public class Test{
final static int a=1;
final void A(){ //final方法
System.out.println(a);
}
}
class FinalTest extends Test{
void A(){ //報(bào)錯(cuò),final方法不能被重寫(xiě)
System.out.println("err");
}
}
final abstract class FinalErr{ //final和abstract不能同時(shí)存在
/*......*/
}
- 詳解Java編程中static關(guān)鍵字和final關(guān)鍵字的使用
- java 中的static關(guān)鍵字和final關(guān)鍵字的不同之處
- java多線程關(guān)鍵字final和static詳解
- Java中final、static關(guān)鍵字與方法的重寫(xiě)和繼承易錯(cuò)點(diǎn)整理
- Java中的static和final關(guān)鍵字的使用詳解
- Java關(guān)鍵字final、static使用總結(jié)
- Java關(guān)鍵字詳解之final static this super的用法
- Java static 與 final關(guān)鍵字實(shí)例詳解
- Java中static與final關(guān)鍵字詳解(簡(jiǎn)單易懂)
相關(guān)文章
基于Java實(shí)現(xiàn)回調(diào)監(jiān)聽(tīng)工具類(lèi)
這篇文章主要為大家詳細(xì)介紹了如何基于Java實(shí)現(xiàn)一個(gè)回調(diào)監(jiān)聽(tīng)工具類(lèi),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-04-04
Spring框架運(yùn)用了多種設(shè)計(jì)模式方式
Spring框架廣泛采用設(shè)計(jì)模式,如工廠模式(BeanFactory)、單例模式、代理模式(AOP)、模板方法模式(JdbcTemplate)等,以實(shí)現(xiàn)高內(nèi)聚、低耦合、可擴(kuò)展和易維護(hù)的架構(gòu),支撐IoC、AOP和MVC等核心特性2025-08-08
java web實(shí)現(xiàn)分頁(yè)查詢(xún)實(shí)例方法
在本篇文章里我們給大家分享了java web實(shí)現(xiàn)分頁(yè)查詢(xún)的詳細(xì)方法知識(shí)點(diǎn),有需要的朋友們參考學(xué)習(xí)下。2018-10-10
圖解Java經(jīng)典算法希爾排序的原理與實(shí)現(xiàn)
希爾排序是希爾(Donald Shell)于1959年提出的一種排序算法。希爾排序也是一種插入排序,它是簡(jiǎn)單插入排序經(jīng)過(guò)改進(jìn)之后的一個(gè)更高效的版本,也稱(chēng)為縮小增量排序,同時(shí)該算法是沖破O(n2)的第一批算法之一。本文會(huì)以圖解的方式詳細(xì)介紹希爾排序的基本思想及其代碼實(shí)現(xiàn)2022-09-09
Spring security用戶(hù)URL權(quán)限FilterSecurityInterceptor使用解析
這篇文章主要介紹了Spring security用戶(hù)URL權(quán)限FilterSecurityInterceptor使用解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12
SpringBoot項(xiàng)目整合Log4j2實(shí)現(xiàn)自定義日志打印失效問(wèn)題解決
這篇文章主要介紹了SpringBoot項(xiàng)目整合Log4j2實(shí)現(xiàn)自定義日志打印失效問(wèn)題解決,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01
SpringBoot+TestNG單元測(cè)試的實(shí)現(xiàn)
本文主要介紹了SpringBoot+TestNG單元測(cè)試的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07

