JAVA单例模式的几种实现方法

1.饿汉
package pattern.singleton;
//
饿汉.初始化,已自行例化
public class Singleton1 {
   
//私有的默构造子
   
private Singleton1() {}
    //自行例化
   
private static final Singleton1single = new Singleton1();
    //工厂方法
   
public static Singleton1getInstance() {
        return single;
    }
}

2.懒汉
package pattern.singleton;
//
懒汉.在第一次用的例化
public class Singleton2 {
   
//私有的默构造子
   
private Singleton2() {}
   
    //注意,里没有final   
    private static Singleton2 single;
   
    //例化一次
   
static{
        single = new Singleton2();
    }
   
    //工厂方法
   
public synchronized  static Singleton2 getInstance() {
         if (single == null) { 
             single = new Singleton2();
         } 
        return single;
    }
}
        在上面懒汉类实现工厂方法使用了同化,以理多线境。有些设计师里建使用所"双重检查成例".指出的是,"双重检查成例"不可以在Java 言中使用。不十分熟悉的者,可以看看后面出的小,由于构造子是私有的,因此,此不能被承。饿汉在自己被加载时就将自己例化。即便加器是静的,在饿汉被加载时仍会将自己例化。源利用效率角度来个比懒汉稍差些。从速度和反应时间角度来懒汉稍好些。然而,懒汉例化,必须处
理好在多个线程同首次引用此类时访问限制问题,特是当为资源控制器,在例化必然源初始化,而源初始化很有可能耗费时间意味着出线程同首次引用此的机率大。
饿汉可以在Java 言内实现但不易在C++ 实现,因初始化在C++ 里没有固定的序,因而静m_instance量的初始化与的加载顺序没有保,可能会出问题就是GoF 在提出的概念的例子是懒汉式的。影响之大,以致Java 言中的例子也大多是懒汉式的。实际上,本书认为饿汉更符合Java 言本身的特点。

3.
.
package pattern.singleton;

import java.util.HashMap;
import java.util.Map;

//
.
//
Spring里面的方法,将名注册,下次从里面直接取。

public class Singleton3 {
   
private staticMap<String,Singleton3> map = new HashMap<String,Singleton3>();
    static{
        Singleton3 single = newSingleton3();
        map.put(single.getClass().getName(),single);
    }
   
    //的默构造子
   
protected Singleton3(){}
   
    //工厂方法,惟一的
   
public static Singleton3getInstance(String name) {
        if(name == null) {
            name =Singleton3.class.getName();
            System.out.println("name ==null"+"--->name="+name);
        }
        if(map.get(name) == null) {
            try {
                map.put(name,(Singleton3) Class.forName(name).newInstance());
            } catch(InstantiationException e) {
                e.printStackTrace();
            } catch(IllegalAccessException e) {
                e.printStackTrace();
            } catch(ClassNotFoundException e) {
                e.printStackTrace();
            }
        }
        return map.get(name);
    }
   
    //一个示意性的商方法
   
public String about() {   
        return "Hello, I amRegSingleton.";   
    }   
    public static void main(String[]args) {
        Singleton3 single3 =Singleton3.getInstance(null);
        System.out.println(single3.about());
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值