单利设计模式
单例设计模式是让某个类在程序的一次运行或者一个运行的容器中只产生一个对象
特征:
- 构造方法私有化
- 将本类对象保存到一个静态属性中
- 提供一个静态方法取得本类对象
什么时候使用:
- 控制资源时使用,通过线程同步起到控制资源的并发访问
- 控制实例数量时使用,达到节约资源的作用
- 做为数据共享时使用,可以在不建立直接关联的条件下,让多个不相关的两个线程或进程间实现数据共享
优点:
1、在内存里只有一个实例,减少了内存的开销,尤其是频繁的创建和销毁实例(比如管理学院首页页面缓存)。
2、避免对资源的多重占用(比如写文件操作)。
缺点:
没有接口,不能继承,与单一职责原则冲突,一个类应该只关心内部逻辑,而不关心外面怎么样来实例化。
饿汉式
package danlisheji;
//饿汉式
public class SingleTon {
//实例化本类对象
private static SingleTon instance = new SingleTon();
//构造方法私有化
private SingleTon(){}
//提供静态方法获取本类对象
public static SingleTon getInstance(){
return instance;
}
}
package danlisheji;
public class test {
public static void main(String[] args) {
System.out.println(SingleTon.getInstance());
System.out.println(SingleTon.getInstance());
System.out.println(SingleTon.getInstance());
}
}
输出:
懒汉式
package danlisheji;
//懒汉式
public class SingleTon {
//实例化本类对象
private static SingleTon instance;
//构造方法私有化
private SingleTon(){}
//提供静态方法获取本类对象
public static SingleTon getInstance(){
if (instance == null) {
instance = new SingleTon();
}
return instance;
}
}
饿汉式:一旦加载SingleTon类就会创建本类对象
线程安全
优点:没有加锁,执行效率会提高。
缺点:类加载时就初始化,浪费内存
懒汉式:只有在第一次调用getInstance方法才会创建本类对象
线程不安全,但可以利用synchronized关键字实现线程同步
优点:第一次调用才初始化,避免内存浪费。
缺点: 必须加锁 synchronized 才能保证单例,但加锁会影响效率。
getInstance() 的性能对应用程序不是很关键(该方法使用不太频繁)。