this,構造器,static,final,單例模式 this關鍵字 在java中this是一個引用變數,即指向當前對象地址的引用(指針),→可以把this當作當前對象,便於更好的索引. this() 實際是調用了當前對象的構造器 1. 引用當前對象的屬性 當在方法中要訪問當前對象的屬性時,可以用t ...
this,構造器,static,final,單例模式
this關鍵字
-
在java中this是一個引用變數,即指向當前對象地址的引用(指針),→可以把this當作當前對象,便於更好的索引.
-
this()
實際是調用了當前對象的構造器 -
1. 引用當前對象的屬性
- 當在方法中要訪問當前對象的屬性時,可以用this來區分局部變數與全局變數.若局部變數和全局變數同名,this指向的屬性是全局變數
public class MyClass { private int value; public MyClass(int value) { this.value = value; // this.value引用的是成員變數value,而value是參數 } public void setValue(int value) { this.value = value; // 同樣,this.value引用的是成員變數value } public int getValue() { return this.value; // 雖然這裡不使用this也能訪問value,但使用this可以增加代碼的可讀性 } }
-
- 調用當前對象的其他方法
- 在方法內部也可以用this來調用當前對象的其他方法,(包括構造方法)
public class MyClass { public MyClass() { this.initialize(); // 調用當前對象的initialize方法 } public void initialize() { // 初始化代碼... } }
-
3.引用當前對象的構造方法
- this()可以在構造方法是調用同一個類的其他構造方法,但必須放在第一行,這樣的好處是實現構造方法的重寫與復用
public class MyClass { private int value; public MyClass() { this(0); // 調用帶有單個參數的構造方法 } public MyClass(int value) { this.value = value; } }
-
- 在事件監聽器中使用
當在事件監聽器(如
ActionListener
)中需要引用觸發事件的組件時,可以使用this
關鍵字(如果監聽器是內部類並且需要引用外部類的實例)。 -
5.在匿名內部類中使用
在匿名內部類(如線程、事件監聽器等)中,
this
關鍵字通常指向外部類的實例,而如果要引用匿名內部類的實例,則沒有直接的this
引用,通常需要使用其他方式(如將匿名內部類的實例賦值給一個變數)。
構造器(構造函數)
-
是創建(new)對象時java會預設調用的方法,通常用給對象傳遞參數來賦值,
-
語法
- 構造函數沒有返回值,沒有void,int 等等
- 構造函數名必須與類名一致
- 在構造函數中要第一所傳入的參數列表→非必須
-
預設構造器
許可權修飾符 類名() { //初始化等功能.. }
-
帶參構造器(常用)
許可權修飾符 類名(數據類型 參數) { //初始化等功能.. }
註意點:
- 如果一個類中只有帶參構造器,則預設的構造器就會被覆蓋→消失,如果還有需要預設構造器,則需顯示性定義
- 同一個類中的構造器可以相互調用,需要用this()來調用,this必須放在第一行→無參構造器托付有參構造器進行構造
public class Person {
private String name;
private int age;
// 無參構造函數
public Person() {
this("Unknown", 0); // 使用this()調用另一個構造函數
//通過this之間調用有參構造函數
}
// 帶兩個參數的構造函數
public Person(String name, int age) {
this.name = name;
this.age = age;
}
// 省略getter和setter方法...
public static void main(String[] args) {
Person unknownPerson = new Person(); // 調用無參構造函數,實際上會委托給帶兩個參數的構造函數
System.out.println("Name: " + unknownPerson.getName() + ", Age: " + unknownPerson.getAge());
Person knownPerson = new Person("John Doe", 30);
System.out.println("Name: " + knownPerson.getName() + ", Age: " + knownPerson.getAge());
}
}
- 在構造器中調用其他構造器,不會創建對象,只會初始化
public class Example {
private int x;
private String y;
// 第一個構造器,帶有兩個參數
public Example(int x, String y) {
this.x = x;
this.y = y;
System.out.println("Two-argument constructor called.");
}
// 第二個構造器,無參數,通過this()調用第一個構造器
public Example() {
this(10, "Default"); // 使用this()調用帶有兩個參數的構造器
System.out.println("No-argument constructor called.");
}
public static void main(String[] args) {
Example obj = new Example(); // 調用無參數構造器
}
}
static關鍵字
記憶體角度分析:當我們執行一個java文件時,java虛擬機會優先載入方法區中的內容,若遇到stati代碼塊,則立即運行.也就是說用static關鍵字修飾的內容在對象還未創建之前就被分配了記憶體空間,這也是我們為什麼能夠直接使用類名.方法或類名.變數名去調用類變數和類方法的原因,也是為什麼我們不能在類方法中使用實例變數和普通方法的原因。
- static一般用來修飾成員變數或者函數
- 被static修飾的變數名叫類變數,方法叫類方法
- 被static關鍵字修飾的不需要去創建對象去調用,可以直接用類名.調用
- 作用:方便再沒有創建對象的情況下來進行調用
簡單理解為被static修飾的方法或變數是存放再方法區與類信息存放在一起
static比實例化對象先分配記憶體空間
final關鍵字
可用來修飾變數和成員方法以及類
final類
- 當final修飾類時,該類不可被繼承.
final方法
- 當一個方法被final修飾時,該方法不可被覆蓋→重寫
- 應用場景:當你希望如果你希望某個方法的行為在整個類層次結構中保持一致,並且不希望被子類改變,那麼你可以將其聲明為
final
final變數
- 實例變數:當一個實例變數被修飾成final時,它只能在聲明時或者構造方法中被賦值,且只能被賦值一次
- 靜態變數:與實例變數情況相同,必須在聲明或者靜態語句塊中被賦值,且只能賦值一次
- 局部變數:即方法中的變數,在聲明時可以不要立即賦值,但使用前必須賦值
final參數
- 當一個方法的參數被final修飾時,在這個方法內部不可再被賦值
單例模式
單例模式:是一種設計模式,它確保一個類只能有一個實例,並提供一個全局訪問的點來訪問這唯一的實例對象, -這個模式在多線程環境和一些需要頻繁創建和銷毀對象但又希望限制這些對象數量的場景中特別有用-。
懶漢式→多線程下不安全,但節省記憶體空間
public class Singleton {
private static Singleton singleton; //
//通過聲明一個靜態的私有成員變數,並且在該類被載入到JVM時立即初始化這個變數
//我們創建了一個類的唯一實例。由於是靜態的,這個實例與類本身相關聯,而不是與類的某個特定實例相關聯。
//同時,由於是私有的,外部代碼無法直接訪問這個變數,只能通過類提供的公共方法來獲取它的值。
private Singleton() { //將構造函數設為私有化,目的是防止外部代碼通過new創建實例對象
//它確保了除了類本身之外,沒有其他代碼能夠實例化這個類
}
public static Singleton getSingleton() {
//外部代碼可以獲取到類的唯一實例。
由於這個方法是靜態的,我們不需要先創建類的實例就可以調用它。
在方法內部,我們檢查instance是否已經被初始化(即是否為null)。
如果是,我們就創建一個新的實例並賦值給singleton;如果不是(即singleton已經被初始化過),我們就直接返回singleton。
由於我們之前已經將構造函數設置為私有,並且singleton是靜態的且只被初始化一次,
所以getSingleton()方法將始終返回同一個實例
if(singleton == null) {
singleton = new Singleton();
}
return singleton;
}
}
- 懶漢式單例模式在第一次被調用時才會創建實例,而不是在類載入時立即創建。
餓漢式→可以適用多線程,但消耗記憶體空間
public class Singleton2 {
Singleton2 類中的靜態成員變數 singleton 在聲明的同時就被初始化了。
這個初始化是在類被 JVM 載入到記憶體時發生的,且只會發生一次。
由於是靜態的,所以不需要創建類的實例就可以訪問它
private static Singleton2 singleton = new Singleton2();
private Singleton2() {
//使外部不能創建singleton
}
public static Singleton2 getSingleton() {
return singleton;
etSingleton() 是一個公共的靜態方法,用於返回 Singleton2 類的單例實例。
由於 singleton 已經在類載入時初始化了,所以無論多少次調用 getSingleton(),
它都會返回同一個實例。
}
}
- 餓漢式即無論如何先創建一個實例化對象,接下來無論幾次調用都返回同一個對象