您的位置:首页 > 编程语言 > Java开发

java单例模式

2017-12-09 14:13 351 查看
一、什么是单例模式

单例模式有以下特点:
  1、单例类只能有一个实例。
  2、单例类必须自己创建自己的唯一实例。
  3、单例类必须给所有其他对象提供这一实例。
  单例模式确保某个类只有一个实例,而且自行实例化并向整个系统提供这个实例。在计算机系统中,线程池、缓存、日志对象、对话框、打印机、显卡的驱动程序对象常被设计成单例。这些应用都或多或少具有资源管理器的功能。每台计算机可以有若干个打印机,但只能有一个Printer
Spooler,以避免两个打印作业同时输出到打印机中。每台计算机可以有若干通信端口,系统应当集中管理这些通信端口,以避免一个通信端口同时被两个请求同时调用。总之,选择单例模式就是为了避免不一致状态,避免政出多头。

二、常见的单例模式有两种创建方式:懒汉式与饿汉式

1、懒汉式(速度慢)

懒汉式就是不在系统加载时就创建的单例,而是在第一次使用实例的时候再创建

示例:

public class Singleton{
private static Singleton singleton = null;
private Singleton(){}
public static synchronized Singleton getInstance(){
if(singleton == null){
dl=new Singleton();
}
return singleton;
}
}
2、饿汉式(占空间)

加载类的时候就会创建类的单例,并保存在类中
示例:
public class Singleton{
private static Singleton singleton = new Singleton();
private Singleton(){}
public static Singleton getInstance(){
return singleton;
}
}
3.双重加锁机制(效率低)
双重加锁机制可以很好的解决懒汉速度慢的问题
示例:
public class Singleton{
private static volatile Singleton singleton = null;
private Singleton(){}
public static Singleton getInstance(){
if(singleton == null){
synchronized(Singleton.class){
if(singleton == null){
singleton = new SIngleton();
}
}
}
return singleton;
}
}
volatile:被其修饰的变量的值不会被本地线程缓存,所有对该变量的读写都是直接操作共享内存实现,从而确保多个线程能正确处理该变量。

4、类级内部类方式(可实现延迟加载和线程安全)
示例:
public class Singleton{
public static class Single
9671
tonSon{
private static Singleton singleton = new Singleton();'
}

private Singleton();'
public static Singleton getInstance(){
return SingletonSon.singleton;
}
}

加载外部类的时候,并不会同时加载其静态内部类,只有发生调用的时候才会进行加载,加载的时候就会创建单例实例并返回,有效实现了懒汉式的延迟加载,至于同步问题,采用和饿汉式相同的静态初始化器的方式,借助JVM来实现线程安全。

spring 中创建的bean实例默认都是单例模式存在的
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息