2022-01-02

2022-01-02  本文已影响0人  嘉宾

1、设计模式

1.1、单例模式

    传统的单例模式有饿汉,和懒汉两种方式,这两种写法中最为经典的且常用的是双重校验的懒汉模式。
传统写法伪代码:
class S {
    private static volitile s;
    
    private s() {
    }

    public S getS() {
        if (s == null) {
            synchronize(this) {
                if (s == null) {
                    s = new S();
                }
            }
        }
        return s;
    }
}

最近比较好的写法有静态内部类实现和枚举单例。

静态内部类伪代码写法:
Class S {
    static class Si {
        private static final S = new S();
    }
}

:当S初始化加载的时候,静态内部类是不会被加载的,只要在调用到Si的时候才会被加载,线程安全有JVM保证,因为JVM保证了相同的类只会加载一次。比传统的饿汉懒汉模式要更好一些。


枚举单例?首先需要问下既然有传统的两种相对比较成熟的单例了,为什么还需要枚举单例?因为私有构造器其实也是不安全的,java中 reflect 破坏了一个类的完整性,通过reflect可以通过设置.setAccessible来访问到私有构造器。
总而言之:jdk1.5之前解决单例线程安全和序列化问题,就是Enum枚举源码那样解决,枚举不能通过反射操作。

枚举单例伪代码:
Enum E {
    INSTANCE;
}
上一篇下一篇

猜你喜欢

热点阅读