单例模式java代码和js代码对比,以及应用

单例模式含义

所谓的单例,就是一个类智能初始化一个实例,而且在系统中被唯一使用,比如一个网站再怎么复杂也只有一个登录框

单例模式的UML类图及解析

在这里插入图片描述
instance前面的减号代表是不能被外部访问的是私有的,-SingleObject是一个私有的构造函数,也是不能被外部访问的。满足了一个类只有一个实例的要求。下面的+getInstance就是返回实例了,+号代表public

所以单例模式需要用到java的private特性

代码

先用java代码理解一下

public class SingleObject{
    //私有的构造函数,只能在内部被实例化
    private SingleObject(){
    }
    // 唯一被new出来的对象
    private SingleObject instance = null
    //获取对象的唯一接口
    public SingleObject getInstance(){
        if(instance == null){
            //唯一实例的一次
            instance = new SingleObject();
        }
        return instance;
    }

    //方法
    public void login(username,password){
        System.out.println("login...")
    }

}
public class SingletonPatternTest{
    public static void main(String[] args){
       // SingleObject singleObject = new SingleObject(); 会报错
		SingleObject singleObject = SingleObject.getInstance()
    }
}

单例模式的ES6写法

class SingleObject {
    init() {
        console.log('单例创建成功');
    }

}

// 注意这个getInstance是一个静态方法,必须卸载class的外面
// 只有这样才能符合单例模式的要求

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

const obj1 = SingleObject.getInstance()
console.log(obj1);
const obj2 = SingleObject.getInstance()
console.log(obj2);

console.log(obj1 === obj2);

// js相对于java不会在new的时候报错,但是new穿件的并不是一个单例
const objNo = new SingleObject()
console.log(objNo);
console.log(objNo === obj1);

注意:这个getInstance是一个静态方法,必须卸载class的外面.,只有这样才能符合单例模式的要求.js相对于java不会在new的时候报错,但是new穿件的并不是一个单例,这点是可以解决的需要更多的代码

应用场景

登录框逻辑


class loginForm {
    constructor() {
        this.state = 'hide'
    }
    show() {
        if (this.state === 'show') {
            console.log('登录框已经被显示,不能重复显示了');
            alert('登录框已经被显示,不能重复显示了')
            return 
        } else {
            this.state = 'show'
            console.log("登录框显示成功");
        }
    }
    close() {
        if (this.state === 'hide') {
            console.log('登录框已经被隐藏了,可以使用show方法显示');
        } else {
            this.state = 'hide'
            console.log('登录框隐藏成功');
        }
    }
}

loginForm.getInstance = (function () {
    let instance = null
    return function () {
        if (!instance) {
            instance = new loginForm()
        }
        return instance
    }
})()

const form1 = loginForm.getInstance()
form1.show()
const form2 = loginForm.getInstance()
form2.show()

效果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值