设计模式-单例模式

介绍

  • 系统中被唯一使用
  • 一个类只有一个实例

示例

  • 登录框
  • 购物车

ULM类图

代码演示

java 复制代码
public class SingleObject {
	// 私有化构造函数,外部不能new,只能内部new!
	private SingleObject() {}
	// 唯一被new出来的对象
	private SingleObject instance = null;
	// 获取对象的唯一接口
	public SingleObject getInstance() {
		if (instance == null) {
			// 只new一次
			instance = new SingleObject();
		}
		return instance;
	}
	// 对象方法
	public void login(username, password) {
		System.out.println("login...");
	}
}

public class SingletonPatternDemo {
	public static void main(String[] args) {
		// 编译时错误,构造函数SingleObject()不可见。
		// SingleObject object = new SingleObject();
		// 获取唯一可用的对象
		SingleObject object = SingleObject.getInstance();
		object.login();
	}
}

JS单例模式

js 复制代码
class SingleObject {
    login() {
        console.log('login...')
    }
}

SingleObject.getInstance = (function() {
    let instance 
    return function () {
        if (!instance) {
            instance = new SingleObject();
        }
        return instance
    }
})()

// 测试: 注意这里只能使用静态函数getInstance,不能new SingleObject() 
let obj1 = SingleObject.getInstance()
obj1.login()
let obj2 = SingleObject.getInstance()
obj2.login()
console.log(obj1 === obj2) // 两者必须完全相等

场景

  • jQuery只有一个$
js 复制代码
// jQuery只有一个$
if (window.jQuery != null) {
    return window.jQuery
} else {
    // 初始化
}
  • 模拟登录框
js 复制代码
class LoginForm {
    contructor() {
        this.state = 'hide'
    }
    
    show() {
        if (this.state === 'show') {
            alert('已经显示')
            return
        }
        this.state = 'show'
        console.log('登录框已显示')
    }
    
    hide() {
        if (this.state === 'hide') {
            alert('已经隐藏')
            return
        }
        this.state = 'hide'
        console.log('登录框已隐藏')
    }
}

LoginForm.getInstance = (function() {
    let instance
    return function() {
        if (!instance) {
            instance = new LoginForm();
        }
        return instance
    }
})()

// 测试
let login1 = LoginForm.getInstance()
login1.show()

let login2 = LoginForm.getInstance()
login2.hide()

console.log('login1 === login2', login1 === login2)
  • 其他
    • 购物车(和登录框类似)
    • vuex和redux中的store

设计原则验证

  • 符合单一职责原则,只实例化唯一的对象
  • 没法具体开放封闭原则,但是绝对不违反开放封闭原则
相关推荐
格图素书1 小时前
大数据在电力行业的应用案例解析-【电力技术】(零)大数据在电力行业的典型落地案例(序)
大数据·单例模式
技术钱1 小时前
react数据大屏四种适配方案
javascript·react.js·ecmascript
花间相见1 小时前
【Java基础面试题】—— 核心知识点面试题(含答案):语法+集合+JVM+设计模式+算法
java·jvm·设计模式
李明卫杭州1 小时前
JavaScript 严格模式下 arguments 的区别
前端·javascript
一次旅行2 小时前
今日心理学知识分享(三)
开发语言·javascript·程序人生·ecmascript
牛十二2 小时前
openclaw安装mcporter搜索小红书
开发语言·javascript·ecmascript
小金鱼Y2 小时前
🔥 前端人必看:浏览器安全核心知识点全解析(XSS/CSRF/DDoS)
前端·javascript·安全
时寒的笔记2 小时前
js逆向05_ob混淆花指令,平坦流,某麦网(突破ob混淆寻找拦截器)
开发语言·前端·javascript
淑子啦3 小时前
React录制视频和人脸识别
javascript·react.js·音视频
代码煮茶3 小时前
Vue3 路由实战 | Vue Router 从 0 到 1 搭建权限管理系统
前端·javascript·vue.js