JavaSE static final及abstract修飾符實例解析
static :靜態(tài)常量,靜態(tài)方法,靜態(tài)代碼塊
靜態(tài)變量: 靜態(tài)變量屬于類的,使用類名來訪問,非靜態(tài)變量是屬于對象的,"必須"使用對象來訪問.
注意:靜態(tài)變量對于類而言在內存中只有一個,能被類中所有的實例共享。 實例變量對于類的每一個實例都有一份,
它們之間互不影在加載類的過程中為靜態(tài)變量分配內存,實例變量在創(chuàng)建對象時分配內存
所以靜態(tài)變量可以使用類名來直接訪問,而不需要使用對象來訪問.
package com.len.collection;public class PersonTest111 { private static String username="戰(zhàn)士高高"; private String password; public static String getUsername() { return username; } public static void setUsername(String username) { PersonTest111.username = username; } public String getPasswoord() { return passwoord; } public void setPasswoord(String passwoord) { this.passwoord = passwoord; } public static void main(String[] args) { /** * 第一點: 靜態(tài)變量屬于類的,可以使用名來訪問,非靜態(tài)變量是屬于對象的,必須使用對象來訪問。 */ System.out.println(PersonTest111.username); PersonTest111 personTest111 = new PersonTest111(); personTest111.setPasswoord("2131231"); System.out.println(personTest111.getPasswoord()); }}
靜態(tài)方法:靜態(tài)方法數(shù)屬于類的,"可以"使用類名來調用,非靜態(tài)方法是屬于對象的,"必須"使用對象來調用.
靜態(tài)方法"不可以"直接訪問類中的非靜態(tài)變量和非靜態(tài)方法,但是"可以"直接訪問類中的靜態(tài)變量和靜態(tài)方法
注意:this和super在類中屬于非靜態(tài)的變量.(靜態(tài)方法中不能使用),代碼同上
靜態(tài)代碼塊:在類加載的時候被調用,給靜態(tài)成員變量賦值
<em>package com.len.collection;
public class PersonTest extends PersonTest111{
private static String username="張珊";
private String password="123456";
public PersonTest(){
System.out.println("構造方法");
}
static {
System.out.println("靜態(tài)代碼塊");
}
public static void main(String[] args) {
PersonTest personTest=new PersonTest();
}
}
</em>
final 修飾符
- 用final修飾的類不能被繼承,沒有子類
- 用final修飾的方法可以被繼承,但是不能被子類的重寫 如java 中每個類都是Object類的子類,繼承了Object中的眾多方法,在子類中可以重寫toString方法、equals方法等,
- 但是不能重寫getClass方法 wait方法等,因為這些方法都是使用fi修飾的
- 用final修飾的變量表示常量,只能被賦一次值.其實使用final修飾的變量也就成了常量了,因為值不會再變了。
2)修飾成員變量:
非靜態(tài)成員變量:
public class PersonTest{
private final int a;
}
只有一次機會,可以給此變量a賦值的位置:
聲明的同時賦
構造器中賦值(類中出現(xiàn)的所有構造器都要寫)
靜態(tài)成員變量:
public class Person{
private static final int a;
}
只有一次機會,可以給此變量a賦值的位置:
聲明的同時賦值
靜態(tài)代碼塊中賦值
abstract修飾符
- 可以用來修飾方法也可以修飾類,如果修飾方法,那么該方法就是抽象方法;如果修飾類,那么該類就是抽象類。
- 抽象類,不能使用new關鍵在來創(chuàng)建對象,它是用來讓子類繼承的,
- 抽象方法,只有方法的聲明,沒有方法的實現(xiàn),它是用來讓子類實現(xiàn)的
注:子類繼承抽象類后,需要實現(xiàn)抽象類中沒有實現(xiàn)的抽象方法,否則這個子類也要聲明為抽象類。
類的創(chuàng)建和初始化過程
* 1.類加載,同時初始化類中的靜態(tài)屬性
* 2.執(zhí)行靜態(tài)代碼塊
* 3.分配內存空間,同時初始化非靜態(tài)的屬性
* 4.調用 PersonTest父類構造器
* 5.對PersonTest中的屬性進行顯示賦值
* 6.執(zhí)行匿名代碼塊
* 7.執(zhí)行構造器
* 8.返回內存地址
package com.len.collection;
public class PersonTest extends PersonTest111{
private static String username="張珊";
private String password="123456";
public PersonTest(){
System.out.println("構造方法");
}
//匿名代碼塊是創(chuàng)建對象的時候自動執(zhí)行,并且是在構造方法之前執(zhí)行給方法
//作用:給對象的成員變量初始化賦值
{
System.out.println("匿名代碼塊");
}
//靜態(tài)方法在類被加載的時候調用
//作用:給靜態(tài)成員變量初始化賦值
static {
System.out.println("靜態(tài)代碼塊");
}
public static void main(String[] args) {
/**
* 1.類加載,同時初始化類中的靜態(tài)屬性
* 2.執(zhí)行靜態(tài)代碼塊
* 3.分配內存空間,同時初始化非靜態(tài)的屬性
* 4.調用 PersonTest父類構造器
* 5.對PersonTest中的屬性進行顯示賦值
* 6.執(zhí)行匿名代碼塊
* 7.執(zhí)行構造器
* 8.返回內存地址
*/
PersonTest personTest=new PersonTest();
}
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
BeanPostProcessor在顯示調用初始化方法前修改bean詳解
這篇文章主要介紹了BeanPostProcessor在顯示調用初始化方法前修改bean詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
詳解spring boot實現(xiàn)多數(shù)據(jù)源代碼實戰(zhàn)
本篇文章主要介紹了詳解spring boot實現(xiàn)多數(shù)據(jù)源代碼實戰(zhàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
Springboot實現(xiàn)人臉識別與WebSocket長連接的實現(xiàn)代碼
這篇文章主要介紹了Springboot實現(xiàn)人臉識別與WebSocket長連接的實現(xiàn),本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11
SpringBoot的@ControllerAdvice處理全局異常詳解
這篇文章主要介紹了SpringBoot的@ControllerAdvice處理全局異常詳解,但有時卻往往會產生一些bug,這時候就破壞了返回數(shù)據(jù)的一致性,導致調用者無法解析,所以我們常常會定義一個全局的異常攔截器,需要的朋友可以參考下2024-01-01

