python类继承重复_python单例模式,可以继承,不会重复执行初始化函数的版本

网上最长见的版本:

1 classSingleton(object):2 __instance=None3 def__init__(self):4 pass

5 def__new__(cls,*args,**kwd):6 if Singleton.__instance isNone:7 Singleton.__instance=object.__new__(cls,*args,**kwd)8 return Singleton.__instance

坑1:每次实例化时,__init__()都会执行一次

原因:python每次实力化一个类先调用__new__方法,再调用__init__方法。在__new__方法中,在不让子类有感知的情况下,无法跳过该机制

坑2:该类无法继承,如果有多个类继承了该基类,那么每次实例化不同的类得到的结果都是第一次实例化时得到的类

原因:__instance作为Singleton这个类的类变量存在,当第一次实例化该类的子类时,__instance被设置为实例化的结果,之后实例化每个子类时,在__new__函数中检测到该变量已设置就不会再去实例化,所以该值也就不会变化。

改进:

classSingleton(object):def __new__(cls, *args, **kwargs):if not hasattr(cls, '__instance'):print('in new')

cls.__instance = object.__new__(cls, *args, **kwargs)

cls.__instance.__Singleton_Init__(*args, **kwargs)return cls.__instance

def __Singleton_Init__(self):print("__Singleton_Init__")

填坑1:该类规定子类的初始化函数是__Singleton_Init__,这样就可以在__new__方法中控制初始化方法的调用

填坑2:__new__方法的cls参数是最上的层子类,判断cls.__instance是否被设置就是在判断各个子类是否有__instance成员变量,这样就可以愉快的继承了

再挖个坑:if not hasattr(cls, '__instance'),为什么这里可以检查cls的“私有成员”

一个例子:

#-*- coding: utf-8 -*-

classSingleton(object):def __new__(cls, *args, **kwargs):if not hasattr(cls, '__instance'):print('before new')print(cls)

cls.__instance = object.__new__(cls, *args, **kwargs)print('after new')

cls.__instance.__Singleton_Init__(*args, **kwargs)return cls.__instance

def __init__(self):print("__init__")def __Singleton_Init__(self):print("__Singleton_Init__")classBB(Singleton):pass

classCC(Singleton):passc=CC()

c1=CC()

b=BB()

b.a=2c.a=3

print(id(c), id(c1))print(b.a, c.a)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值