深入理解java设计模式之单例模式

(内容代码大部分来自http://blog.csdn.net/jason0539

今天看了一天的设计模式。

单例模式:常用的分为两种 懒汉模式和饿汉模式

单例模式:

1、单例类确保自己只有一个实例。

2、单例类必须自己创建自己的实例。

3、单例类必须为其他对象提供唯一的实例。

举个例子,网站的计数器就是单例模式的一个体现。因为总不能打开一次网址就去new一个新的计数器对象。而是大家都去用一个计数器

下面来点干货 

数据库的连接池一般也是使用单例模式去实现的。

单例模式常用的分为两种

懒汉模式:

//懒汉式单例类.在第一次调用的时候实例化自己   
public class Singleton {  
    private Singleton() {}  
    private static Singleton single=null;  
    //静态工厂方法   
    public static Singleton getInstance() {  
         if (single == null) {    
             single = new Singleton();  
         }    
        return single;  
    }  
} 


public class Singleton {    
    private static class LazyHolder {                 
       private static final Singleton INSTANCE = new Singleton();    //使用静态内部类的方式实现线程安全,这个没研究。
    }    
    private Singleton (){}    
    public static final Singleton getInstance() {    
       return LazyHolder.INSTANCE;    
    }    
} 

考虑到线程可能并发的可能,所以懒汉模式是线程不安全的。然而我们可以去使用 synchronized 这个方法让所有的访问去同步,从而实现线程安全

但是在网上看java有反射机制,通过Java反射机制是能够实例化构造方法为private的类的,这里姑且先不考虑反射机制。但是我们的知道!

饿汉模式:

//饿汉式单例类.在类初始化时,已经自行实例化   
public class Singleton1 {  
    private Singleton1() {}  
    private static final Singleton1 single = new Singleton1();  
    //静态工厂方法   
    public static Singleton1 getInstance() {  
        return single;  
    }  
}  

饿汉式在类创建的同时就已经创建好一个静态的对象供系统使用,以后不再改变,所以天生是线程安全的。而且是最终的不可改变的final类型

 

懒汉与饿汉的区别:

饿汉式天生就是线程安全的,可以直接用于多线程而不会出现问题,

懒汉式本身是非线程安全的,为了实现线程安全得用syn方法去实现/静态内部类。

饿汉式在类创建的同时就实例化一个静态对象出来,不管之后会不会使用这个单例,都会占据一定的内存,但是相应的,在第一次调用时速度也会更快,因为其资源已经初始化完成,

而懒汉式顾名思义,会延迟加载,在第一次使用该单例的时候才会实例化对象出来,第一次调用时要做初始化,如果要做的工作比较多,性能上会有些延迟,之后就和饿汉式一样了。

posted @ 2017-11-28 19:42  皇后  阅读(346)  评论(0编辑  收藏  举报