java 单例模式



设计模式:让代码可重用,让代码更容易被他人理解、保证代码可靠性。
经典设计模式分为三种类型。
    创建模型式:单例模式、工厂模式等
    结构型模式:装饰模式、代理模式等
    行为型模式:模版方法模式、迭代器模式等
单例设计模式:意图:保证一个类仅有一个实例,并提供一个访问它的全局访问点。使用性:
当前只能有一个实例而且客户可以从一个众所周知的访问它。任何情况下,该类只能创建一个实例!
单例设计模式创建步骤:1.定义一个私有的静态的当前类类型的属性。2私有化构造方法。
3.定义一个静态的可以获取当前类实例的方法。这个方法中我们可以判断是否创建过实例,创
建过就直接返回,从而达到单例的效果。

单例模式是一种对象创建模式,用于生产一个对象的具体实例,他保证系统中一个类只产生一个实例,单例模式的好处:

1、对于频繁使用的对象,可以省略对象创建的时间

2、由于new操作的次数减少,因而对系统内存的使用频率也会降低,减轻GC压力,缩短GC停顿时间

单例模式主要针对于系统的关键组件和被频繁使用的对象,使用它可以有效改善系统的性能。

单例类必须要有:1、private访问级别的构造函数,只有这样才能确保单例不会在系统的其他代码内被实例化;2、instance(实例对象)和getInstance()(获取实例对象的方法)方法必须是static


单例模式实现方式一:

  1. public class Singleton01 {  
  2.     private Singleton01(){  
  3.         System.out.println("singleton is create");  
  4.     }  
  5.     private static  Singleton01 singleton01=new Singleton01();  
  6.     public static  Singleton01 getInstance(){  
  7.         return singleton01;  
  8.     }  
  9. }  
public class Singleton01 {
	private Singleton01(){
		System.out.println("singleton is create");
	}
	private static  Singleton01 singleton01=new Singleton01();
	public static  Singleton01 getInstance(){
		return singleton01;
	}
}

不足:无法对singleton实例做延迟加载,如果这个单例类在系统中还扮演其他角色,那么在任何使用这个单例类的地方都会初始化这个单例类变量

如:

  1. public class Singleton01 {  
  2.     private Singleton01(){  
  3.         System.out.println("singleton is create");  
  4.     }  
  5.     private static  Singleton01 singleton01=new Singleton01();  
  6.     public static  Singleton01 getInstance(){  
  7.         return singleton01;  
  8.     }  
  9.     public static void createString(){  
  10.         System.out.println("createString in Singleton");  
  11.     }  
  12.       
  13. }  
public class Singleton01 {
	private Singleton01(){
		System.out.println("singleton is create");
	}
	private static  Singleton01 singleton01=new Singleton01();
	public static  Singleton01 getInstance(){
		return singleton01;
	}
	public static void createString(){
		System.out.println("createString in Singleton");
	}
	
}
  1. public class SingleTonTest {  
  2.     public static void main(String[] args) {  
  3.           
  4.         Singleton01.createString();  
  5.     }  
  6. }  
public class SingleTonTest {
	public static void main(String[] args) {
		
		Singleton01.createString();
	}
}




实现方式二(使用懒加载):

  1. public class SingleTon02 {  
  2.     private SingleTon02(){  
  3.         System.out.println("lazySingleTon is create");  
  4.     }  
  5.     private static SingleTon02 instance=null;  
  6.     public  static synchronized SingleTon02 getInstance(){  
  7.         if(instance==null){  
  8.             instance=new SingleTon02();  
  9.         }  
  10.         return instance;  
  11.           
  12.     }  
  13. }  
public class SingleTon02 {
	private SingleTon02(){
		System.out.println("lazySingleTon is create");
	}
	private static SingleTon02 instance=null;
	public  static synchronized SingleTon02 getInstance(){
		if(instance==null){
			instance=new SingleTon02();
		}
		return instance;
		
	}
}

说明:1、静态成员变量instance初始值赋予null,保证在系统启动时没有额外的负载;

    2、在getInstatance()工厂方法中,判断单例是否存在,如果存在直接返回,如不存在则创建;

    3、getInstance()方法必须同步,否则在多线程情况下,当线程1正新建实例时,线程2可能判断instance为null,从而导致多个实例被创建。

不足:由于使用同步关键字,因此在多线程情况下,他的时耗远大于第一种单例模式。


实现方式三(使用内部类):

  1. public class SingleTon03 {  
  2.     private SingleTon03(){  
  3.         System.out.println("staticSingle is create");  
  4.     }  
  5.     private static class SingleHolder{  
  6.         private static SingleTon03 instance=new SingleTon03();  
  7.     }  
  8.     public static SingleTon03 getInstance(){  
  9.         return SingleHolder.instance;  
  10.     }  
  11. }  
public class SingleTon03 {
	private SingleTon03(){
		System.out.println("staticSingle is create");
	}
	private static class SingleHolder{
		private static SingleTon03 instance=new SingleTon03();
	}
	public static SingleTon03 getInstance(){
		return SingleHolder.instance;
	}
}

说明:1、单例模式使用内部类来维护到单例的实例,当SingleTon3被加载时,其内部类并不会被初始化,因此单例类被加载jvm时,不会初始化单例类,而当getInstance()方法被调用时,才加载SingleHolder(内部类),从而初始化instance。

   2、此种方式实例创建是在类加载时完成,因此天生对多线程友好,getInstance方法不必使用同步关键字

   3、使用内部类方式实现单例,既可以做到延迟加载,也不必使用关键字,是一种比较完善的时间。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值