Я переопределяю метод __new__()
класса, чтобы вернуть экземпляр класса, который имеет определенный набор __init__()
. Python, кажется, вызывает метод __init__()
, предоставляемый классом, вместо специфичного для экземпляра метода, хотя документация Python в
http://docs.python.org/reference/datamodel.html
говорит:
Типичные реализации создают новый экземпляр класса, вызывая суперклассы __новый метод __() с использованием super (currentclass, cls).__ new __ (cls [,...]) с соответствующими аргументами, а затем изменения вновь созданного экземпляра как необходимо, прежде чем возвращать его.
Если __new __() возвращает экземпляр cls, то новые экземпляры __init __() будет вызываться как __init __ (self [,...]), где self - это новый экземпляр и остальные аргументы те же, что и для __new __().
Здесь мой тестовый код:
#!/usr/bin/env python
import new
def myinit(self, *args, **kwargs):
print "myinit called, args = %s, kwargs = %s" % (args, kwargs)
class myclass(object):
def __new__(cls, *args, **kwargs):
ret = object.__new__(cls)
ret.__init__ = new.instancemethod(myinit, ret, cls)
return ret
def __init__(self, *args, **kwargs):
print "myclass.__init__ called, self.__init__ is %s" % self.__init__
self.__init__(*args, **kwargs)
a = myclass()
который выводит
$ python --version
Python 2.6.6
$ ./mytest.py
myclass.__init__ called, self.__init__ is <bound method myclass.myinit of <__main__.myclass object at 0x7fa72155c790>>
myinit called, args = (), kwargs = {}
Кажется, единственный способ получить myinit()
для запуска - явно называть его self.__init__()
внутри myclass.__init__()
.