单例

作者: 阿发贝塔伽马 | 来源:发表于2017-10-24 19:29 被阅读0次

new实现单例

new至少要有一个参数cls,代表要实例化的类,new方法负责创建一个实例对象,在对象被创建的时候调用该方法它是一个类方法,new方法负责创建一个实例对象,在对象被创建的时候调用该方法它是一个类方法。new方法在返回一个实例之后,会自动的调用init方法,对实例进行初始化。如果new方法不返回值,或者返回的不是实例,那么它就不会自动的去调用init方法。此参数在实例化时由Python解释器自动提供

class Singleton(object):
    def __new__(cls, *args, **kwargs):
        print cls,'xxxx'
        if not hasattr(cls,"_instance"):
            cls._instance = super(Singleton, cls).__new__(cls, *args, **kwargs)
        
        return cls._instance

元类实现单例

class Singleton(type):
    def __init__(self, *args, **kwargs):
        print "__init__"
        self.__instance = None
        super(Singleton,self).__init__(*args, **kwargs)

    def __call__(self, *args, **kwargs):
        print "__call__"
        if self.__instance is None:
            self.__instance = super(Singleton,self).__call__(*args, **kwargs)
        return self.__instance


class Foo(object):
    __metaclass__ = Singleton #在代码执行到这里的时候,元类中的__new__方法和__init__方法其实已经被执行了,而不是在Foo实例化的时候执行。且仅会执行一次。只有再需要对原类做变动时才需要写new方法

为了更好理解上面单例,注意下面两种写法

class UpperAttrMetaClass(type):
    
    def __new__(upperattr_metaclass, future_class_name, future_class_parents, future_class_attr):
        print 'xxxxxxx'
        uppercase_attr = {}
        for name, value in future_class_attr.items():
            if not name.startswith('__'):
                uppercase_attr[name.upper()] = value
            else:
                uppercase_attr[name] = value
        return type.__new__(upperattr_metaclass,future_class_name, future_class_parents, uppercase_attr)#返回一个对象,但同时这个对象是一个类
    
    def __init__(upperattr_metaclass,*args, **kwargs):
        print 'init'
        upperattr_metaclass.__instance = None
        super(UpperAttrMetaClass,upperattr_metaclass).__init__(*args, **kwargs)
    def myprint(self, param):
        print param,'xxxxx'

    def __call__(upperattr_metaclass,*args, **kwargs):
        print 'call'
    #  return upperattr_metaclass
        if upperattr_metaclass.__instance is None:
            upperattr_metaclass.__instance = super(UpperAttrMetaClass,upperattr_metaclass ).__call__(*args, **kwargs)
        return upperattr_metaclass.__instance

下面两种写法 ,

class Test(object):
    __metaclass__ = UpperAttrMetaClass
    def __call__(self):
        print 'test call'
    def __new__(cls, *args, **kwargs):
        print 'test new'
        return super(Test, cls).__new__(cls,*args, **kwargs)
    def __init__(self):
        print 'test init'
    def myprint(self, param):
        print param
    aaaa = 22222
class Test(object):
    def __call__(self):
        print 'test call'
    def myprint(self, param):
        print param
    aaaa = 22222

Test = UpperAttrMetaClass('Test', (object,), {'myprint':Test().myprint, '__call__':Test().__call__, 'aaaa':Test().aaaa}) 

这里我们重写了call方法,一开始不理解

super(UpperAttrMetaClass,upperattr_metaclass ).__call__(*args, **kwargs)

为什么能得到实例,如果我们不重写call方法,Test()将得到实例对象,那么重写的话,重写的格式就是这样,在Test类中重写new,init方法这时被调用。

t = Test()

t.MYPRINT('xxx')
t2 = Test()
print t 
print t2.AAAA
print Test()

相关文章

  • Android设计模式总结

    单例模式:饿汉单例模式://饿汉单例模式 懒汉单例模式: Double CheckLock(DCL)实现单例 Bu...

  • IOS单例模式的底层原理

    单例介绍 本文源码下载地址 1.什么是单例 说到单例首先要提到单例模式,因为单例模式是单例存在的目的 单例模式是一...

  • 【设计模式】单例模式

    单例模式 常用单例模式: 懒汉单例模式: 静态内部类单例模式: Android Application 中使用单例模式:

  • 2020-11-02-Spring单例 vs. 单例模式

    Spring 单例不是 Java 单例。本文讨论 Spring 的单例与单例模式的区别。 前言 单例是 Sprin...

  • IOS学习笔记之单例

    单例介绍 1.什么是单例 说到单例首先要提到单例模式,因为单例模式是单例存在的目的 单例模式是一种常用的软件设计模...

  • OC - 单例模式

    导读: 一、什么是单例模式 二、单例的作用 三、常见的单例类 四、自定义单例类的方法 一、什么是单例模式 单例模式...

  • 单例

    单例 单例宏

  • 单例模式

    特点 单例类只有1个实例对象 该单例对象必须由单例类自行创建 单例类对外提供一个访问该单例的全局访问点 结构 单例...

  • 关于java单例模式,这篇已经讲得很清楚了,建议收藏!

    概念 java中单例模式是一种常见的设计模式,单例模式分三种:懒汉式单例、饿汉式单例、登记式单例三种。 特点 单例...

  • 单例

    iOS单例模式iOS之单例模式初探iOS单例详解

网友评论

      本文标题:单例

      本文链接:https://www.haomeiwen.com/subject/hipxpxtx.html