zoukankan      html  css  js  c++  java
  • 二十二.面向对象 单例模式

    一. 单例模式

    单例模式:基于某种方法实例化多次得到实例是同一个
    当实例化多次得到的对象中存放的属性都一样的情况,应该将多个对象指向同一个内存,即同一个实例
    减少内存占用

    类内部定义静态方法实现单例模式

    class Da(object):
        def __init__(self,age,name):
            self.age=age
            self.name=name
        def aa(self):
            print("单例模式哈哈哈哈")
    v=None
    while True:
        if v:
            v.aa()
        else:
            v = Da("555", "张三")
            v.aa()
    class People():
        __instance = None
        @classmethod
        def from_conf(cls):
            if cls.__instance:
                   return  cls.__instance
            else:
                cls.__instance=People()
                return  cls.__instance
    a1=People.from_conf()
    print(a1)
    
    a1=People.from_conf()
    print(a1)
    a1=People.from_conf()
    print(a1)
    
    print("*****************************************************************88")
    
    class People():
        __instance = None
        @classmethod
        def from_conf(cls):
            if cls.__instance:
                return cls.__instance
    
            cls.__instance = cls()
            return cls.__instance
    
    aa=People.from_conf()
    print(aa)
    
    a2=People.from_conf()
    print(a2)

    装饰器实现单例模式

    #
    # 代码分析:第1行,创建外层函数singleton,可以传入类
    #      第2行,创建一个instances字典用来保存单例
    #      第3行,创建一个内层函数来获得单例
    #      第4,5,6行, 判断instances字典中是否含有单例,如果没有就创建单例并保存到instances字典中,然后返回该单例
    #      第7行, 返回内层函数get_instance


    # 使用装饰器实现单例模式
    # 可以看出,虽然进行了两次实例化,但是仍然为同一个实例。
    def singleton(cls, *args, **kwargs):
    instance = {}
    def _instance():
    if cls not in instance:
    instance[cls] = cls(*args, *kwargs)
    return instance[cls]
    return _instance
    @singleton
    class Test_singleton:
    def __init__(self):
    self.num = 0
    def add(self):
    self.num = 99
    ts1 = Test_singleton()
    ts2 = Test_singleton()
    ts3 = Test_singleton()
    print(ts1)
    print(ts2)
    print(ts3)
    print(ts3 is ts1)
    print(id(ts1))
    print(id(ts2))

    # <__main__.Test_singleton object at 0x0000017C71418F60>
    # <__main__.Test_singleton object at 0x0000017C71418F60>
    # <__main__.Test_singleton object at 0x0000017C71418F60>
    # True
    # 1412705718112
    # 1412705718112


    print("***********************************************************************888")


    # 没有实现单例模式 实例化一下就产生有一个内存空间
    class Test:
    def __init__(self):
    self.num = 0
    def add(self):
    self.num = 99

    ts1=Test()
    ts2=Test()
    ts3=Test()
    print(ts1)
    print(ts2)
    print(ts3)
    print(ts3 is ts1)


    # <__main__.Test object at 0x0000017C71422048>
    # <__main__.Test object at 0x0000017C71422080>
    # <__main__.Test object at 0x0000017C714220B8>
    # False
     
    #
    # 代码分析:第1行,创建外层函数singleton,可以传入类
    #      第2行,创建一个instances字典用来保存单例
    #        第3行,创建一个内层函数来获得单例
    #        第4,5,6行, 判断instances字典中是否含有单例,如果没有就创建单例并保存到instances字典中,然后返回该单例
    #        第7行, 返回内层函数get_instance
    
    
     # 使用装饰器实现单例模式
    # 可以看出,虽然进行了两次实例化,但是仍然为同一个实例。
    def singleton(cls,*args,**kwargs):
        instance = {}
        def _instance(*args, **kwargs):
            if cls not in instance:
                instance[cls] = cls(*args, *kwargs)
            return instance[cls]
        return _instance
    @singleton
    class Test:
        def __init__(self,aa,name):
            self.aa=aa
            self.name=name
    ts1 = Test(666,"李四")
    ts2 = Test(333,"王五")
    print(ts1)
    print(ts2)
    print(ts1 is  ts2)
    print(id(ts1))
    print(id(ts2))
    # <__main__.Test object at 0x000001FED67C88D0>
    # <__main__.Test object at 0x000001FED67C88D0>
    # True
    # 2194031806672
    # 2194031806672
    print(ts1.aa)
    print(ts2.aa)
    
    print(ts1.name)
    print(ts2.name)
    #
    # 666
    # 666
    # 李四
    # 李四
    class Person(object):
    
        def __init__(self,name,age):
            self.name=name
            self.age=age
    
    
    alex=Person("alex",33)
    egon=Person("egon",32)
    
    单例模式
    

    单例模式方式1 :
    __new__ class Singleton(object): _instance = None def __new__(cls, *args, **kw): if not cls._instance: cls._instance = super(Singleton, cls).__new__(cls, *args, **kw) return cls._instance class MyClass(Singleton): a = 1 mc1=MyClass() mc2=MyClass() mc3=MyClass() print(id(mc1)) print(id(mc2)) print(id(mc3))

    
    

    单例模式 模块方式

     mysingleton.py
    
    
    class My_Singleton(object):
        def foo(self):
            print("foo.....")
    
    
    my_singleton = My_Singleton()
    func.py
    
    
    from mysingleton import my_singleton
    
    def bar():
        print(id(my_singleton))
    
    
    import time


    
    
    main.py 执行文件


    from
    mysingleton import my_singleton,My_Singleton my_singleton.foo() print(id(my_singleton)) 思考1 from mysingleton import my_singleton as my_singleton_new print(id(my_singleton_new)) print(id(my_singleton)) 思考2 import func func.bar() 思考3 from mysingleton import my_singleton,My_Singleton ms1=My_Singleton() from mysingleton import my_singleton,My_Singleton ms2=My_Singleton() print(id(ms1)) print(id(ms2))

    执行结果

    foo.....
    47583824
    47583824
    47583824
    47583824
    46795536
    46795632

  • 相关阅读:
    【OpenGL】Shader实例分析(七)- 雪花飘落效果
    BZOJ 1091([SCOI2003]分割多边形-分割直线)
    Protocol buffer序列化及其在微信蓝牙协议中的应用
    运行计划中cost计算方法
    jquery全局变量---同步请求设置
    Java split字符串中包含.的情况
    jQuery获取、设置title的值
    jQuery获取URL中所带参数的办法
    在Eclipse中提交SVN项目的时候注意提交项目信息
    马丁 福勒 Martin Fowler 关于依赖注入和反转控制的区别
  • 原文地址:https://www.cnblogs.com/Sup-to/p/11094767.html
Copyright © 2011-2022 走看看