使用方法: 1、__new__()方法中至少需要传入一个参数cls; 2. __new__() 必须有返回值,返回实例化的实例。
Python中的__new__()方法的使用
__new__() 函数只能用于从object继承的新式类。
先看下object类中对__new__()方法的定义:
class object:
@staticmethod # known case of __new__
def __new__(cls, *more): # known special case of object.__new__
""" T.__new__(S, ...) -> a new object with type S, a subtype of T """
pass
object将__new__()方法定义为静态方法,至少需要传递一个参数cls。 cls代表需要实例化的类。该参数在实例化时由 Python 解释器自动提供。
我们来看下下面类中对__new__()方法的实现:
class Demo(object):
def __init__(self):
print '__init__() called...'
def __new__(cls, *args, **kwargs):
print '__new__() - {cls}'.format(cls=cls)
return object.__new__(cls, *args, **kwargs)
if __name__ == '__main__':
de = Demo()
输出:
当发现一个对象被实例化时,先调用__new__()方法,然后再调用__init__()进行初始化
__new__() 必须有一个返回值并返回实例化的实例。需要注意的是,可以返回父类__new__()中的实例,也可以直接返回object的__new__()中的实例。
__init__()有一个参数self,self参数是__new__()返回的实例,__init__()可以在__new__()的基础上完成一些其他的初始化动作,__init__()不需要返回值。
如果 __new__() 没有正确返回当前类 cls 的实例,那么 __init__() 将不会被调用,即使它是父类的实例。
我们可以将其类比为制造商。 __new__()方法是前期的原材料采购环节,__init__()方法是在原材料的基础上对产品环节进行处理和初始化。
实际应用过程中,我们可以这么使用:
class LxmlDocument(object_ref):
cache = weakref.WeakKeyDictionary()
__slots__ = ['__weakref__']
def __new__(cls, response, parser=etree.HTMLParser):
cache = cls.cache.setdefault(response, {})
if parser not in cache:
obj = object_ref.__new__(cls)
cache[parser] = _factory(response, parser)
return cache[parser]
该类中使用__new__()方法是为了在初始化前检查对象是否存在于缓存中。如果存在,则直接返回缓存中存储的对象。如果不存在,则将该对象放入缓存中供下载。使用次数。
再来个单例的,通过重载__new__实现单例:
class Singleton(object):
def __new__(cls, *args, **kwargs):
if not hasattr(cls, '_instance'):
cls._instance = super(Singleton, cls).__new__(cls, *args, **kwargs)
return cls._instanc
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ pandas 中的 join() 方法如何用于合并索引?10/31
- ♥ Python中有多少关键字?09/15
- ♥ 如何解决python的print函数不输出的问题09/25
- ♥ 什么是python轮08/30
- ♥ 如何在python3中使用argparse模块?12/29
- ♥ Python 新手 FAQ 1:搞乱表达式01/13
内容反馈