2
3
4
|
__new__()在__init__()之前被调用,用于生成实例对象。利用这个方法和类的属性的特点可以实现设计模式的单例模式。单例模式是指创建唯一对象,单例模式设计的类只能实例
实例化 1 个对象。
class Singleton( object ):
__instance = None
def__init__( self ):
pass
def__new__( cls , * args, * * kwd):
if Singleton.__instance is None :
Singleton.__instance = object .__new__( cls , * args, * * kwd)
return Singleton.__instance
class Singleton( object ):
__instance = None
def__init__( self ):
pass
def__new__( cls , * args, * * kwd):
if Singleton.__instance is None :
Singleton.__instance = object .__new__( cls , * args, * * kwd)
return Singleton.__instance
2.3 新式类(new-style class)
新式类除了拥有经典类的全部特性之外,还有一些新的特性。比如__init__发生了变化,
新增了静态方法__new__
2.3.1 __init__方法
据说在python2.4版本以前,使用新式类时,如果类的初始化方法没有定义,调用的
时候写了多余的参数,编译器不会报错。我现在的python 2.7会报错,还是觉得会报错
比较好点,下面给出新式类和经典类运行这个例子的情况:
2.3.2 __new__静态方法
新式类都有一个__new__的静态方法,它的原型是object.__new__(cls[, ...])
cls是一个类对象,当你调用C(*args, **kargs)来创建一个类C的实例时,python的内部调用是
C.__new__(C, *args, **kargs),然后返回值是类C的实例c,在确认
c是C的实例后,python再调用C.__init__(c, *args, **kargs)来初始化实例c。
所以调用一个实例c = C(2),实际执行的代码为:
c = C.__new__(C, 2)
if isinstance(c, C): C.__init__(c, 23)#__init__第一个参数要为实例对象
object.__new__()创建的是一个新的,没有经过初始化的实例。当你重写__new__方法时,可以不
用使用装饰符@staticmethod指明它是静态函数,解释器会自动判断这个方法为静态方法。如果
需要重新绑定C.__new__方法时,只要在类外面执行C.__new__ = staticmethod(yourfunc)就可以了。
可以使用__new__来实现Singleton单例模式:
class Singleton(object):
_singletons = {} def __new__(cls): if not cls._singletons.has_key(cls): #若还没有任何实例 cls._singletons[cls] = object.__new__(cls) #生成一个实例 return cls._singletons[cls] #返回这个实例
运行结果如下:
使用id()操作,可以看到两个实例指向同一个内存地址。Singleton的所有子类也有这一
特性,只有一个实例对象,如果它的子类定义了__init__()方法,那么必须保证它的
__init__方法能够安全的同一个实例进行多次调用。
|
python单例模式
最新推荐文章于 2023-09-21 23:06:30 发布