什么是sington设计模式呢,这个应该是23种java常用设计模式中使用最多的模式之一。
Sington又称单例设计模式,即保证该模式下的类有且只有一个对象,方便进行一个统一的操作。
单例模式分别分为懒汉式,饿汉式和双重锁模式。下面来介绍一下这三种模式下的单例。
懒汉式
package cn.com.testspring;
/**
* Created by Administrator on 2017/10/11 0011.
*/
public class SingTon {
//私有化无参构造方法,防止外部类在使用new 类名();的方式获取到当前类对象
private SingTon() {
}
//静态化对象保证单例
private static SingTon singTon = null;
//提供一个公共的方法对这个单例进行访问
public static SingTon getSingTon() {
//获取这个对象时先判断是否为空;若空则创建这个对象,否则就会直接返回已经创建好的对象
if (singTon == null)
singTon = new SingTon();
return singTon;
}
}
饿汉式:
package cn.com.testspring;
/**
* Created by Administrator on 2017/10/11 0011.
*/
public class SingTon {
//私有化无参构造方法,防止外部类在使用new 类名();的方式获取到当前类对象
private SingTon() {
}
//直接使用静态并创建好这个对象
private static SingTon singTon = new SingTon();
//直接返回不做任何处理,也可保证单例
public static SingTon getSingTon() {
return singTon;
}
}
双重锁式:
package cn.com.testspring;
/**
* Created by Administrator on 2017/10/11 0011.
*/
public class SingTon {
//私有化无参构造方法,防止外部类在使用new 类名();的方式获取到当前类对象
private SingTon() {
}
//静态化对象保证单例
private static SingTon singTon = null;
/**
* 多线程操作过程中避免不了这个单例是同步的,所以现在我们来给这个单例模式加一个synchronized关键字
* 关于这个synchronized关键字,如果不进行处理的话,当多线程进行操作使用的时候会进行阻塞,导致其他线程进入等待状态
* 且,即使这个单例对象在上一个线程中已经完成创建,这个锁依然会被触发,且阻塞后面线程,
* 所以,这样的单例设计是不合理的。
*
*
* public static SingTon getSingTon() {
* synchronized (SingTon.class) {
* if (singTon == null)
* singTon = new SingTon();
* }
* return singTon;
* }
*/
/**
* 这里我们在进入这个锁之前进行一次判断,就可避免若多个线程同时到达这里会进行阻塞,但在第一个线程完成创建后
* 此后访问的线程将不会进入这个锁中,直接就可获得这个单例对象。
* 大大提高了多线程下单例模式的性能。
* @return
*/
public static SingTon getSingTon() {
if (singTon == null)
synchronized (SingTon.class) {
if (singTon == null)
singTon = new SingTon();
}
return singTon;
}
}
总结
目前单例来说就上面介绍的比较常用,相信还会有更加完善的设计方式。但是无论怎样处理都是为了保证单例对象的唯一性。
————————-
:面临困难不能着急,周全考虑解决办法;拿到办法不能怠缓,尽快执行果决落实。该做的事要下决心去做,决心做的事要坚定不移做好!