大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

Java多線程編程概述
Java多線程的安全問題
Java多線程同步
Java多線程間的通信
Java線程Lock
Java多線程管理
保障線程安全的設計技術
Java鎖的優化及注意事項
Java多線程集合
【Java多線程】單例模式與多線程

Java單例模式懶漢和餓漢式

單例設計模式是最常用的設計模式之一.單例模式提供了一種在多線程環境中保證實例唯一性的解決方案。

餓漢模式

餓漢模式也叫立即加載模式,立即加載就是在使用類時就已經將對象初始化完畢。

package com.wkcto.sigleton.p1;

/**
 * 餓漢單例模式
 *  在類加載內存時就給對象初始化,具有固有的線程安全性
 *  餓漢模式適用于成員屬性比較少,占用內存資源不多的情況
 */
public class Test {
    public static void main(String[] args) {
        //創建10個線程, 在每個 線程中打印單例對象
        for (int i = 0; i < 10; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    //調用Singleton.getInstance()返回單例對象,打印會輸出對象的哈希碼
                    System.out.println(Singleton.getInstance());
                }
            }).start();
        }
        //程序運行后,輸出單例的哈希碼都相同,說明是同一個對象
    }
}
package com.wkcto.sigleton.p1;

import java.util.Random;

/**
 * 單例類
 */
public class Singleton {
    //在使用Singleton單例類時,就給靜態變量obj初始化. 在類加載內存時就已經對類的實例初始化完畢,保證在多線程環境中的唯一
    private static Singleton obj = new Singleton();
    private Singleton(){}
    public static Singleton getInstance(){
        try {
            Thread.sleep(new Random().nextInt(50));
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return obj;
    }
}
懶漢模式

懶漢模式也稱為延遲加載. 延遲加載就是在第一次調用get()方法時才給實例進行初始化。

package com.wkcto.sigleton.p2;

/**
 * 測試單例模式
 */
public class Test {
    public static void main(String[] args) {
        //創建10個線程, 在每個 線程中打印單例對象
        for (int i = 0; i < 10; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    //調用Singleton.getInstance()返回單例對象,打印會輸出對象的哈希碼
                    System.out.println(Singleton.getInstance());
                }
            }).start();
        }
    }
}
package com.wkcto.sigleton.p2;

import java.util.Random;

/**
 * 懶漢單例
 *  不是線程安全的
 */
public class Singleton1 {
    //定義本類實例,不初始化
    private static Singleton1 obj;
    private Singleton1(){}
    //在第一次調用getInstance()方法時,判斷obj是否為null,如果obj為null就進行初始化
    public static Singleton1 getInstance(){
        if ( obj == null ){
            try {
                Thread.sleep(new Random().nextInt(50));     //睡眠,模擬多線程執行需要的時間,
                //加上睡眠后,運行結果可能會出現多個實例的情況,這種延遲加載不是線程安全的
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            obj = new Singleton1();
        }
        return obj;
    }
}
package com.wkcto.sigleton.p2;

import java.util.Random;

/**
 * 懶漢單例
 *  既然多個 線程可以同時調用getInstance()方法,只需要對該方法進行同步即可
 *  對整個方法進行了同步,并發效率低,即一個線程必須等上個線程釋放鎖之后才能取得 鎖對象獲得單例
 */
public class Singleton2 {
    //定義本類實例,不初始化
    private static Singleton2 obj;
    private Singleton2(){}
    //在第一次調用getInstance()方法時,判斷obj是否為null,如果obj為null就進行初始化
    public static synchronized Singleton2 getInstance(){
        if ( obj == null ){
            try {
                Thread.sleep(new Random().nextInt(50));     //睡眠,模擬多線程執行需要的時間,
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            obj = new Singleton2();
        }
        return obj;
    }
}
package com.wkcto.sigleton.p2;

import java.util.Random;

/**
 * 懶漢單例
 *  直接同步getInstance()方法,并發效率低,可以只針對部分重要代碼進行同步
 *  即只針對 給obj對象初始化的語句進行同步,也可能存在線程安全問題
 */
public class Singleton3 {
    //定義本類實例,不初始化
    private static Singleton3 obj;
    private Singleton3(){}
    //在第一次調用getInstance()方法時,判斷obj是否為null,如果obj為null就進行初始化
    public static  Singleton3 getInstance(){
        if ( obj == null ){
            try {
                Thread.sleep(new Random().nextInt(50));     //睡眠,模擬多線程執行需要的時間,
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            synchronized (Singleton3.class) {
                obj = new Singleton3();
            }
        }
        return obj;
    }
}
package com.wkcto.sigleton.p2;

import java.util.Random;

/**
 * 懶漢單例
 *  直接同步getInstance()方法,并發效率低,可以只針對部分重要代碼進行同步
 *  如果只針對 給obj對象初始化的語句進行同步,也可能存在線程安全問題
 *  可以采用雙檢查機制,在同步代碼塊中再次檢查obj對象是否為null
 */
public class Singleton {
    //定義本類實例,不初始化
    private static Singleton obj;
    private Singleton(){}
    //在第一次調用getInstance()方法時,判斷obj是否為null,如果obj為null就進行初始化
    public static Singleton getInstance(){
        if ( obj == null ){
            try {
                Thread.sleep(new Random().nextInt(50));     //睡眠,模擬多線程執行需要的時間,
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            synchronized (Singleton.class) {
                if (obj == null) {      //再次檢查obj是否為null
                    obj = new Singleton();
                }
            }
        }
        return obj;
    }
}
全部教程
主站蜘蛛池模板: 亚洲国产高清视频在线观看 | 国内自拍小视频 | 久久的爱久久久久的快乐 | 久久久在线视频 | 国产精品久久久久久久久久免费 | 久久久精品在观看999 | 两性色午夜视频免费老司机 | 日本久久综合视频 | 日本aa在线观看 | 91福利视频网站 | 日韩一级欧美一级一级国产 | 国产成年女一区二区三区 | 青青草国产97免久久费观看 | 99久久中文字幕伊人情人 | 青青青国产免费全部免费观看 | 欧美另类久久久精品 | 久久久伊香蕉网站 | 国产色视频一区二区三区 | 91成人午夜在线精品 | 亚洲欧洲毛片 | 黄色网址中文字幕 | 久青草视频在线播放 | 亚洲成人高清在线 | 四虎国产精品免费五月天 | 亚洲一区二区三区高清 不卡 | 日韩免费黄色片 | 精品免费久久久久久影院 | 亚洲国产一区二区三区a毛片 | 四虎影视最新 | 国产精品免费视频一区 | 91国在线| 精品在线免费视频 | 国产一级αv片免费观看 | 欧美一级视频在线观看欧美 | 成人精品一区久久久久 | 五月天丁香婷婷综合 | 日韩欧美一二三区 | 大陆一级毛片免费视频观看 | 97国产在线观看 | 点击进入不卡毛片免费观看 | 男人边吃奶边爱边做视频日韩 |