目录
- 项目中合理的运用设计模式可以完美的解决很多问题
- 每种模式在现在中都有相应的原理来与之对应
- 每—一个模式描述了一个在我们周围不断重复发生的问题,以及该问题的核心解决方案
- 面向对象的设计模式很多,但大家认为这23个模式是其它模式的基础
单例模式
- 滚滚历史,朝代更迭,永恒定律
- 一个朝代皇帝只有一个
- 军队的最高司令官只有一个
- 山不容二虎
- 计算机系统
- 驱动程序
- 打印机后台处理程序
- 线程池
- 缓存
- 日志
要点:
- 某个类只能有一个实例
- 必须自行创建实例
- 必须自行向整个系统提供这个实例
实现:
- 只提供私有的构造方法
- 包含一个该类的静态私有对象
- 提供一个静态的公有方法用于创建、获取静态私有对象
代码实现方案:
- 饿汉式
package com.imooc.singleton;
//饿汉式:创建对象实例的时候直接初始化 空间换时间
public class SingletonOne {
// 1.创建类中的私有构造
private SingletonOne() {
}
// 2.创建该类型的私有静态实例
private static SingletonOne instance = new SingletonOne();
// 3.创建公有静态方法返回静态实例对象
public static SingletonOne getInstance() {
return instance;
}
}
- 懒汉式
package com.imooc.singleton;
//懒汉式 : 类内实例对象创建时并不直接初始化,直到第一次调用get方法时,才完成初始化操作
//时间换空间
public class SingletonTwo {
// 1.创建类中的私有构造
private SingletonTwo() {
}
// 2.创建静态的该类实例对象
private static SingletonTwo instance = null;
// 3.创建开放的静态方法提供实例对象
public static SingletonTwo getInstance() {
if (instance == null)
instance = new SingletonTwo();
return instance;
}
}
饿汉式PK懒汉式
1、饿汉式在类加载时就创建实例,第一次加载速度快
懒汉式第一次使用时才进行实例化,第一次加载速度慢
- 饿汉式:空间换时间
- 懒汉式:时间换空间
2、饿汉式线程安全;懒汉式存在线程风险
解决方案
- 同步锁
- 静态内部类
- 双重校验锁
- 枚举
优点:
- 在内存中只有一个对象、节省内存空间
- 避免频繁的创建和销毁对象,提高性能
- 避免对共享资源的多重占用
缺点:
- 扩展比较困难
- 如果实例化后的对象长期不利用,系统将默认为垃圾进行回收,造成对象状态丢失
适用场景:
- 创建对象时占用资源过多,但同时又需要用到该类对象
- 对系统内资源要求统一读写,如读写配置信息
- 当多个实例存在可能引起程序逻辑错误,如号码生成器