zoukankan      html  css  js  c++  java
  • 单例模式总结

    一、枚举类实现单例(线程最安全的一种,但是使用的比较少)

    public enum InstanceTest {
         instance;
         public void test(){
             System.out.println("这是一个枚举类型的单例!");
         }
     }

    二、静态内部类实现单例(线程安全的)

     public class InstanceTest {
         private InstanceTest(){}
         
         private static class single{
             private static final InstanceTest instance=new InstanceTest();
         }
         
         public InstanceTest getInstance(){
             return single.instance;
         }
     }

    当类加载器加载该类时,静态内部类首先不会被加载,当调用getInstance方法时,由于要使用静态内部类的instance属性,此时才会去加载静态内部类,所以会延迟加载。

    三、饿汉式单例

    public class InstanceTest {
         private InstanceTest(){}
         
         private static InstanceTest instance=new InstanceTest();
         
         public static InstanceTest getInstance(){
             return instance;
         }
     }

    线程安全的,该类第一次加载时就会创建一个实例,并发访问时一直是同一个实例所以是线程安全的,但实例的创建是依赖参数或者配置文件的,在getInstance()之前必须调用某个方法设置参数给它时该方式就行不通了。

    四、懒汉式单例(线程不安全的)

    public class InstanceTest {
         private InstanceTest(){}
         
         private static InstanceTest instance=null;
         
         public static InstanceTest getInstance(){
             return instance=new InstanceTest();
         }
     }

    多个线程访问时,调用getInstance方法,可能创建不同的实例,所以不是线程安全的,加同步代码块的话会对性能有一定的影响。

    双检锁式单例在java中存在问题,由于java的内存模型,java的内存模型存在无序写入问题

    参考博客 http://blog.csdn.net/chenchaofuck1/article/details/51702129

  • 相关阅读:
    Problem C: 爬楼梯
    Problem E: 倒水(Water)
    Problem H: tmk买礼物
    HDU 1078 FatMouse and Cheese
    POJ 3186 Treats for the Cows
    POJ 1661 Help Jimmy
    POJ 1458 Common Subsequence
    2018-软工机试-D-定西
    2018-软工机试-F-庙会
    2018-软工机试-C-和你在一起
  • 原文地址:https://www.cnblogs.com/coderising/p/5886613.html
Copyright © 2011-2022 走看看