我知道(?)关于
Python中__new__构造函数背后的理论,但我要问的是常见的做法 – 这个构造函数真正用于什么目的(!)?
我已经读过初始化不可变对象(逻辑从__init__移到__new__),其他什么?工厂模式?
请再次注意区别:
>对于什么任务__new__可以使用 – 我不感兴趣
>对于使用__new__的任务 – 我是:-)
我不用Python写任何东西,我的知识来自阅读,而不是来自经验.
你可以在哪里回答这个问题:Common practice of new constructor?
解决方法
__new__的要点是创建一个__init__然后初始化的空对象实例.重新实现__new__你可以完全控制你创建的实例,但是你没有实际使用__init__方法来进行任何进一步的处理.我可以给你两个有用的案例:使用智能构造函数从类的磁盘自动创建方法和反序列化.这些不是解决这两个问题的唯一方法.元类是另一种更灵活的方式,但作为任何工具,您可能希望获得不同程度的复杂性.
假设您想要一个具有给定属性集的类.您可以控制如何使用这样的代码初始化这些属性
class Foo(object): properties = [] def __new__(cls,*args): instance = object.__new__(cls,*args) for p in cls.properties: setattr(instance,p,0) return instance class MyFoo(Foo): properties = ['bar','baz'] def __init__(self): pass f=MyFoo() print dir(f)
您想要的属性直接初始化为零.您可以执行许多智能技巧,例如动态执行属性列表.实例化的所有对象都将具有这些方法.这个模式的一个更复杂的例子出现在Django Models中,你可以在这里声明字段并免费获得大量自动内容,感谢__new__大哥,元类.
从磁盘反序列化
假设您有一个具有给定构造函数的类,该构造函数从对象填充类的字段,例如进程:
class ProcessWrapper(object): def __init__(self,process): self._process_pid = process.pid() def processpid(self): return self._process_pid
如果现在将此信息序列化到磁盘并想要恢复它,则无法通过构造函数进行初始化.所以你编写了这样的反序列化函数,有效地绕过了你无法运行的__init__方法.
def deserializeProcessWrapperFromFile(filename): # Get process pid from file process = ProcessWrapper.__new__() process._process_pid = process_pid return process
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。