java单例模式

一、什么是单例模式

单例模式有以下特点:
  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 SingletonSon{

private static Singleton singleton = new Singleton();'

}


private Singleton();'

public static Singleton getInstance(){

return SingletonSon.singleton;

}

}


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


spring 中创建的bean实例默认都是单例模式存在的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值