线程安全的单列模式(4种)
2017-11-09 21:10
337 查看
1.不使用同步锁
2.使用同步方法
上述代码中的一次锁住了一个方法, 这个粒度有点大 ,改进就是只锁住其中的new语句就OK。就是所谓的“双重锁”机制。
3.使用双重同步锁
4.使用内部类,既不用加锁,也能实现懒加载
public class Singleton { private static Singleton s = new Singleton();//直接初始化一个实例对象 private Singleton() {///private类型的构造函数,保证其他类对象不能直接new一个该对象的实例 System.out.println("Singleton"); } public static Singleton getSingle() {//该类唯一的一个public方法 return s; } }上述代码中的一个缺点是该类加载的时候就会直接new 一个静态对象出来,当系统中这样的类较多时,会使得启动速度变慢 。现在流行的设计都是讲“延迟加载”,我们可以在第一次使用的时候才初始化第一个该类对象。所以这种适合在小系统。
2.使用同步方法
public class Singleton { private static Singleton instance; private Singleton() {} public static synchronized Singleton getIntance() {//对获取实例的方法进行同步 if(instance == null) { instance = new Singleton(); } return instance; } }
上述代码中的一次锁住了一个方法, 这个粒度有点大 ,改进就是只锁住其中的new语句就OK。就是所谓的“双重锁”机制。
3.使用双重同步锁
public class Singleton { private static Singleton instance; private Singleton() {} public static Singleton getInstance() { if(instance == null) { synchronized (Singleton.class) { if(instance == null) { instance = new Singleton(); } } } return instance; } }
4.使用内部类,既不用加锁,也能实现懒加载
public class Singleton4 { private Singleton4() { System.out.println("single"); } private static class Inner { private static Singleton4 s = new Singleton4(); } public static Singleton4 getSingle() { return Inner.s;//返回一个类的静态对象,只有调用这语句内部类才会初始化,所以能实现赖加载 } }
相关文章推荐
- Lazy方式单列模式,一种线程安全模式的新选择
- 设计模式____单列模式(懒加载,常加载,双检索,线程安全问题)
- c++单列模式与线程安全
- 线程安全的单列模式
- 多线程下线程安全的单列模式
- Activity 的4种启动模式,分析的简单全面
- 如何正确理解和使用Activity的4种启动模式
- 最适合教育个体户的4种网校平台运营模式
- ActionScript3单列模式的一种实现
- 简单的单列模式
- ObjectFactory采用单列模式设置工厂模式
- 线程安全的单例模式
- 【Android】【Activity】Activity的4种加载模式及Intent标识
- Android activity的4种启动模式,launchMode,图文详解
- 高并发下线程安全的单例模式(最全最经典)
- 4种activity的启动模式
- ARM 寄存器的在4种模式下的不同视图
- 单例模式——C++实现线程安全的单例
- Android网络(4):HttpClient必经之路----使用线程安全的单例模式HttpClient,及HttpClient和Application的融合
- 线程安全的单例模式