设为首页 收藏本站
查看: 2462|回复: 6

[经验分享] python的单例模式

[复制链接]

尚未签到

发表于 2013-3-12 08:40:43 | 显示全部楼层 |阅读模式
python单例模式
所谓单例,就是保证一个类仅有一个实例。所有引用(实例、对象)拥有相同的状态(属性)和行为(方法);
同一个类的所有实例天然拥有相同的行为(方法);
只需要保证同一个类的所有实例具有相同的状态(属性)即可;
所有实例共享属性的最简单最直接的方法就是__dict__属性指向(引用)同一个字典(dict)

单例模式动机
对于系统中的某些类来说,只有一个实例很重要,例如,一个系统中可以存在多个打印任务,但是只能有一个正在打印的任务;一个系统中只能有一个串口管理器或文件系统;一个系统只能有一个计时工具或ID生成器。如在window是中就只能打开一个任务管理器。如果不使用机制对窗口对象进行唯一化,将弹出多个窗口,如果这些窗口显示的内容完全一致,则是重复对象,浪费内存资源;如果这些窗口显示的内容不一致,则意味着在某一瞬间系统有多个状态,与实际不符,也会给用户带来误解,不知道哪个才是真实的状态。因为有时确保系统中某个对象的唯一性(即一个类只有一个实例)非常重要。
如何保证一个类只有一个实例并且这个实例易于被访问呢?定义一个全局变量可以确保对象随时都可以被访问,但不能阻止我们实例化多个对象。一个更好的方法是让类自身负责保存它的唯一实例。这个类可以保证没有其他实例被创建,并且它可以提供一个访问该实例的方法。这就是单例模式的模式动机。
单例模式要点
一是某个类只能有一个实例;
二是它必须自行创建这个实例;
三是它必须自行向整个系统提供这个实例。
从具体实现角度来说,就是一下三点:
一是单例模式的类只提供私有的构造函数;
二是类定义中含有一个该类的静态私有对象;
三是该类提供了一个静态的共有的函数用于创建或获取它本身的静态私有对象。

实现单例模式方法1:

  • [Python] 纯文本查看 复制代码
    #/usr/bin/python 
    #-*- encoding=utf-8 -*-    
     
    #方法1,实现__new__方法    
    #并在将一个类的实例绑定到类变量_instance上,    
    #如果cls._instance为None说明该类还没有实例化过,实例化该类,并返回    
    #如果cls._instance不为None,直接返回cls._instance    
    class Singleton(object):   
        def __new__(cls, *args, **kw):   
            if not hasattr(cls, '_instance'):   
                orig = super(Singleton, cls)   
                cls._instance = orig.__new__(cls, *args, **kw)   
            return cls._instance   
       
    class MyClass(Singleton):   
        a = 1   
       
    one = MyClass()   
    two = MyClass()   
       
    two.a = 3   
    print one.a   
    #3    
    #one和two完全相同,可以用id(), ==, is检测    
    print id(one)   
    #29097904    
    print id(two)   
    #29097904    
    print one == two   
    #True    
    print one is two   
    #True    
    实现单例模式方法2:
    #方法2,共享属性;所谓单例就是所有引用(实例、对象)拥有相同的状态(属性)和行为(方法)    
    #同一个类的所有实例天然拥有相同的行为(方法),    
    #只需要保证同一个类的所有实例具有相同的状态(属性)即可    
    #所有实例共享属性的最简单最直接的方法就是__dict__属性指向(引用)同一个字典(dict)    
    #可参看:[url]http://code.activestate.com/recipes/66531/[/url]    
    class Borg(object):   
        _state = {}   
        def __new__(cls, *args, **kw):   
            ob = super(Borg, cls).__new__(cls, *args, **kw)   
            ob.__dict__ = cls._state   
            return ob   
       
    class MyClass2(Borg):   
        a = 1   
       
    one = MyClass2()   
    two = MyClass2()   
       
    #one和two是两个不同的对象,id, ==, is对比结果可看出    
    two.a = 3   
    print one.a   
    #3    
    print id(one)   
    #28873680    
    print id(two)   
    #28873712    
    print one == two   
    #False    
    print one is two   
    #False    
    #但是one和two具有相同的(同一个__dict__属性),见:    
    print id(one.__dict__)   
    #30104000    
    print id(two.__dict__)   
    #30104000    
    实现单例模式方法3:
    #方法3:本质上是方法1的升级(或者说高级)版    
    #使用__metaclass__(元类)的高级python用法    
    class Singleton2(type):   
        def __init__(cls, name, bases, dict):   
            super(Singleton2, cls).__init__(name, bases, dict)   
            cls._instance = None   
        def __call__(cls, *args, **kw):   
            if cls._instance is None:   
                cls._instance = super(Singleton2, cls).__call__(*args, **kw)   
            return cls._instance   
       
    class MyClass3(object):   
        __metaclass__ = Singleton2   
       
    one = MyClass3()   
    two = MyClass3()   
       
    two.a = 3   
    print one.a   
    #3    
    print id(one)   
    #31495472    
    print id(two)   
    #31495472    
    print one == two   
    #True    
    print one is two   
    #True    
    实现单例模式方法4:
    #方法4:也是方法1的升级(高级)版本,    
    #使用装饰器(decorator),    
    #这是一种更pythonic,更elegant的方法,    
    #单例类本身根本不知道自己是单例的,因为他本身(自己的代码)并不是单例的    
    def singleton(cls, *args, **kw):   
        instances = {}   
        def _singleton():   
            if cls not in instances:   
                instances[cls] = cls(*args, **kw)   
            return instances[cls]   
        return _singleton   
      
    @singleton   
    class MyClass4(object):   
        a = 1   
        def __init__(self, x=0):   
            self.x = x   
       
    one = MyClass4()   
    two = MyClass4()   
       
    two.a = 3   
    print one.a   
    #3    
    print id(one)   
    #29660784    
    print id(two)   
    #29660784    
    print one == two   
    #True    
    print one is two   
    #True    
    one.x = 1   
    print one.x   
    #1    
    print two.x   
    #1   



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-3758-1-1.html 上篇帖子: python多线程处理重复任务10000次 下篇帖子: Python实现Factory Method模式 set oracle Windows python

尚未签到

发表于 2013-3-19 02:43:07 | 显示全部楼层
帮你顶下哈!!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

发表于 2013-5-17 10:52:14 | 显示全部楼层
美女未抱身先走,常使色狼泪满襟。。。。。。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

尚未签到

发表于 2013-5-20 18:08:11 | 显示全部楼层
禽兽尚且有半点怜悯之心,而我一点也没有,所以我不是禽兽。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

尚未签到

发表于 2013-5-24 19:09:47 | 显示全部楼层
沒有激情的亲吻,哪來床上的翻滾?

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

尚未签到

发表于 2013-5-31 12:40:30 | 显示全部楼层
我的id是假冒的,大家不要相信我是骗子。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

尚未签到

发表于 2013-6-5 13:55:20 | 显示全部楼层
精典之极就是精斑!!!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表