首页 > 编程语言 > 详细

javascript单例模式(懒汉 饿汉)

时间:2014-05-19 20:41:13      阅读:462      评论:0      收藏:0      [点我收藏+]

第一种:懒汉模式

bubuko.com,布布扣
var Singleton=(function(){
    var instantiated;  //比较懒,在类加载时,不创建实例,因此类加载速度快,但运行时获取对象的速度慢
    function init(){
        /*这里定义单例代码*/
        return{
            publicMethod:function(){
                console.log(‘helloworld‘);
            },
            publicProperty:3
        };
    }
    return{
        getInstance:function(){
            if(!instantiated){
                instantiated=init();
            }
            return instantiated;
        }
    };
})();
/*可在其他类调用公有的方法或属性来获取实例:*/
Singleton.getInstance().publicMethod();
Singleton.getInstance().publicProperty = 4;
console.log(Singleton.getInstance().publicProperty);
bubuko.com,布布扣

 

第二种:饿汉模式

bubuko.com,布布扣
var Singleton=(function(){
    var instantiated = init();  //比较饿,在类加载时就完成了初始化,所以类加载较慢,但获取对象的速度快
    function init(){
        /*这里定义单例代码*/
        return{
            publicMethod:function(){
                console.log(‘helloworld‘);
            },
            publicProperty:3
        };
    }
    return{
        getInstance:function(){
            return instantiated;
        }
    };
})();
bubuko.com,布布扣

 

 

javascript单例模式(懒汉 饿汉),布布扣,bubuko.com

javascript单例模式(懒汉 饿汉)

原文:http://www.cnblogs.com/rhythm2014/p/3731604.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!