【读书笔记】设计模式 - 单例模式

神马是单例模式?简单的讲,就是某个构造函数,有且仅有一个实例存在,无论你调用该构造函数来创建实例多少次,如:

function Class(){}    //仅仅用来举例

var instance_01 = new Class();
var instance_02 = new Class();

console.log( instance_01===instance_02 );    //输出:true

 

我们知道,在javascript,当且仅当 instance_01instance_02 指向的是 同一个实例对象,上述表达式才有可能输出为true,换言之,即:

如果instance_01 instance_02 指向的不是同一个实例对象,即使 instance_01 与 instance_02 拥有完全相同的属性值,上述表达式也会输出 false

可以做个小测试:

复制代码
function Wife( name ){
    this.name = name;
}
Wife.prototype.shout = function(){
    console.log( 'i\'m your only wife '+ this.name +' , do remember !');
};

var wife_01 = new Wife( 'Marry' );
var wife_02 = new Wife( 'Mary' );

console.log( wife_01===wife_02 );    //尽管名字相同,但输出为:false,妻子竟然有两个,天~~
复制代码

 

那么,最上面举的那个例子是怎么实现的呢?

最简单直观的思路:第一次调用该构造函数创建实例对象的时候,可以将该实例对象的引用保存下来,接下来,当该构造函数被再次调用,无论多少次,都只是返回之前保存的那个实例对象

还是用 妻子 那个例子:

复制代码
function Wife( name ){
    if( Wife.instance ){
        return Wife.instance;
    }
    Wife.instance = this;
    this.name = name;
}

Wife.prototype.shout = function(){
    console.log( 'i\'m your only wife '+ this.name +' , do remember !');
};    
var wife_01 = new Wife( 'Marry' );
wife_01.shout();    //输出:i'm your only wife Marry , do remember !

var wife_02 = new Wife( 'Lucy' );
wife_02.shout();    //输出:i'm your only wife Marry , do remember !

console.log( wife_01===wife_02 );    //输出:true
复制代码

 

很好,现在已经符合一夫一妻制的要求了,但总觉得有些不对劲——如果有人将 Wife.instance 恶意修改了,那不久悲剧了

针对于此,打个小补丁:

复制代码
var Wife = (function(){
    var instance = null;    //外部无法直接访问,于是安全了
    var _wife = function( name ){
        if( instance ){
            return instance;
        }
        instance = this;
        this.name = name;
    }
    return _wife;
})();

Wife.prototype.shout = function(){
    console.log( 'i\'m your only wife '+ this.name +' , do remember !');
};    
var wife_01 = new Wife( 'Marry' );
wife_01.shout();    //输出:i'm your only wife Marry , do remember !

var wife_02 = new Wife( 'Lucy' );
wife_02.shout();    //输出:i'm your only wife Marry , do remember !

console.log( wife_01===wife_02 );    //输出:true
复制代码

 

OVER

posted @   程序猿小卡  阅读(1315)  评论(1编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示