单例模式:
单例模式,顾名思义就是只有一个实例,并且她本人负责创立本人的对象,这个类提供了一种拜访其惟一的对象的形式,能够间接拜访,不须要实例化该类的对象
单例模式,属于创立类型
理论代码我放在了Github: https://github.com/liangtengy...
利用场景:
学习一个设计模式之前 咱们先理解它的应用场景可能帮咱们更快的了解它,
单例模式只容许创立一个对象,因而更节俭内存,放慢对象访问速度,因而对象须要被专用的场合适宜应用,如多个模块应用同一个数据源连贯对象等等.如:
- 须要频繁实例化而后销毁的对象。
- 创建对象时耗时过多或者耗资源过多,但又常常用到的对象。
- 有状态的工具类对象。
- 频繁拜访数据库或文件的对象。
实现形式:
饿汉式
public class Singleton_3 { //应用饿汉式 线程平安 private static Singleton_3 instance = new Singleton_3() ; private Singleton_3() { } public static Singleton_3 getInstance() { return instance; }}
懒汉式 - 线程平安
public class Singleton_2 { //应用懒汉式 线程平安 不倡议应用 private static Singleton_2 instance =null ; private Singleton_2() { } public synchronized static Singleton_2 getInstance() { if (instance !=null) return instance; return new Singleton_2(); }}
懒汉式 - 非线程平安
public class Singleton_1 { //应用懒汉式 非线程平安 private static Singleton_1 instance =null ; private Singleton_1() { } public static Singleton_1 getInstance() { if (instance !=null) return instance; return new Singleton_1(); }}
动态类形式
public class sigleton0 { //应用动态类形式实现单例 private static ConcurrentHashMap cache = new ConcurrentHashMap();}
外部类形式
public class Singleton_4 { //应用外部类形式结构单例, 线程平安并且懒加载 private AtomicInteger id = new AtomicInteger(0); private Singleton_4() { } public static Singleton_4 getInstance(){ return SingletonCreator.singleton_4; } private static class SingletonCreator{ static Singleton_4 singleton_4 = new Singleton_4(); } public Integer getIncrementId(){ return this.id.getAndIncrement(); }
双重校验锁形式
public class Singleton_5 { //应用双重锁校验 线程平安 private static Singleton_5 instance =null ; //满足懒加载 private Singleton_5() { } public static Singleton_5 getInstance() { if (instance !=null) return instance; synchronized (Singleton_5.class) { if (instance == null) { return new Singleton_5(); } } return new Singleton_5(); }}
原子类形式
public class Singleton_6 { //应用atomicrefence 应用CAS形式 反对懒加载 private static AtomicReference<Singleton_6> INSTANCE = new AtomicReference<Singleton_6>(); private Singleton_6() { } public static Singleton_6 getInstance(){ for (; ; ) { Singleton_6 singleton_6 = INSTANCE.get(); if (null != singleton_6)return singleton_6; INSTANCE.compareAndSet(null, new Singleton_6()); return INSTANCE.get(); } }
试验
每次获取单例对象的后果理论都是同一个对象
public static void main(String[] args) { for (int i = 0; i < 100; i++) { //获取实例 Singleton_4 instance = Singleton_4.getInstance(); //输入地址 System.out.println("实例的地址:" + instance); //获取id System.out.println(instance.getIncrementId()); System.out.println("-------------------------------------------------"); }}
后果 :
实例的地址:Singleton_4@63947c6b0-------------------------------------------------实例的地址:Singleton_4@63947c6b1-------------------------------------------------实例的地址:Singleton_4@63947c6b2-------------------------------------------------实例的地址:Singleton_4@63947c6b3------------------------------------------------- .....
关注公众号:java宝典