日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql jdbc 单利_java单利模式设计

發布時間:2024/9/27 数据库 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql jdbc 单利_java单利模式设计 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

java中單例模式是一種常見的設計模式,單例模式分三種:懶漢式單例、餓漢式單例、登記式單例三種。

Singleton是一種創建型模式,指某個類采用Singleton模式,則在這個類被創建后,只可能產生一個實例供外部訪問,并且提供一個全局的訪問點。

核心知識點如下:

(1) 將采用單例設計模式的類的構造方法私有化(采用private修飾)。

(2) 在其內部產生該類的實例化對象,并將其封裝成private static類型。

(3) 定義一個靜態方法返回該類的實例。

/*** 方法一

* 單例模式的實現:餓漢式,線程安全 但效率比較低

*/

public classSingletonTest {

// 定義一個私有的構造方法

privateSingletonTest() {

}

// 將自身的實例對象設置為一個屬性,并加上Static和final修飾符

private static final SingletonTest instance = newSingletonTest();

// 靜態方法返回該類的實例

public staticSingletonTest getInstancei() {

returninstance;

}

}

方法一就是傳說的中的餓漢模式

優點是:寫起來比較簡單,而且不存在多線程同步問題,避免了synchronized所造成的性能問題;

缺點是:當類SingletonTest被加載的時候,會初始化static的instance,靜態變量被創建并分配內存空間,從這以后,這個static的instance對象便一直占著這段內存(即便你還沒有用到這個實例),當類被卸載時,靜態變量被摧毀,并釋放所占有的內存,因此在某些特定條件下會耗費內存。

/***方法二

* 單例模式的實現:飽漢式,非線程安全

*

*/

public classSingletonTest {

// 定義私有構造方法(防止通過 new SingletonTest()去實例化)

privateSingletonTest() {

}

// 定義一個SingletonTest類型的變量(不初始化,注意這里沒有使用final關鍵字)

private staticSingletonTest instance;

// 定義一個靜態的方法(調用時再初始化SingletonTest,但是多線程訪問時,可能造成重復初始化問題)

public staticSingletonTest getInstance() {

if (instance == null)

instance = newSingletonTest();

returninstance;

}

}

方法二就是傳說的中的飽漢模式

優點是:寫起來比較簡單,當類SingletonTest被加載的時候,靜態變量static的instance未被創建并分配內存空間,當getInstance方法第一次被調用時,初始化instance變量,并分配內存,因此在某些特定條件下會節約了內存;

缺點是:并發環境下很可能出現多個SingletonTest實例。

/***方法三

* 單例模式的實現:飽漢式,線程安全簡單實現

*

*/

public classSingletonTest {

//定義私有構造方法(防止通過 new SingletonTest()去實例化)

privateSingletonTest() {

}

//定義一個SingletonTest類型的變量(不初始化,注意這里沒有使用final關鍵字)

private staticSingletonTest instance;

//定義一個靜態的方法(調用時再初始化SingletonTest,使用synchronized 避免多線程訪問時,可能造成重的復初始化問題)

public static synchronizedSingletonTest getInstance() {

if (instance == null)

instance = newSingletonTest();

returninstance;

}

}

方法三為方法二的簡單優化

優點是:使用synchronized關鍵字避免多線程訪問時,出現多個SingletonTest實例。

缺點是:同步方法頻繁調用時,效率略低。

/**

* 方法四

* 單例模式最優方案

* 線程安全 并且效率高

*

*/

public class SingletonTest {

// 定義一個私有構造方法

private SingletonTest() {

}

//定義一個靜態私有變量(不初始化,不使用final關鍵字,使用volatile保證了多線程訪問時instance變量的可見性,避免了instance初始化時其他變量屬性還沒賦值完時,被另外線程調用)

private static volatile SingletonTest instance;

//定義一個共有的靜態方法,返回該類型實例

public static SingletonTest getIstance() {

// 對象實例化時與否判斷(不使用同步代碼塊,instance不等于null時,直接返回對象,提高運行效率)

if (instance == null) {

//同步代碼塊(對象未初始化時,使用同步代碼塊,保證多線程訪問時對象在第一次創建后,不再重復被創建)

synchronized (SingletonTest.class) {

//未初始化,則初始instance變量

if (instance == null) {

instance = new SingletonTest();

}

}

}

return instance;

}

}

方法四為單例模式的最佳實現。內存占用地,效率高,線程安全,多線程操作原子性。

(事實上,可以通過Java反射機制來實例化private類型的構造方法,此時基本上會使所有的Java單例實現失效。本帖不討論反射情況下問題,默認無反射,也是常見的面試已經應用場景)

總結

以上是生活随笔為你收集整理的mysql jdbc 单利_java单利模式设计的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。