Recientemente leí an interesting discussion on how to make a singleton in Python. Una de las soluciones fue un tricky decorator defining a class inside its code as a substitute for decorated class:¿Por qué ocurre una recursión aquí?
def singleton(class_):
class class_w(class_):
_instance = None
def __new__(class2, *args, **kwargs):
if class_w._instance is None:
class_w._instance = super(class_w, class2).__new__(class2, *args, **kwargs)
class_w._instance._sealed = False
return class_w._instance
def __init__(self, *args, **kwargs):
if self._sealed:
return
super(class_w, self).__init__(*args, **kwargs)
self._sealed = True
class_w.__name__ = class_.__name__
return class_w
@singleton
class MyClass(object):
def __init__(self, text):
print text
@classmethod
def name(class_):
print class_.__name__
x = MyClass(111)
x.name()
y = MyClass(222)
print id(x) == id(y)
de salida es:
111 # the __init__ is called only on the 1st time
MyClass # the __name__ is preserved
True # this is actually the same instance
Se afirma, que si usamos el interior super(MyClass, self).__init__(text)
__init__
de MyClass
, de entrar en recursividad.
He probado y de hecho ocurre la recursividad. Pero, según tengo entendido, MyClass
hereda object
, por lo super(MyClass, self)
sólo debe ser meramente object
, pero resulta que super(MyClass, self)
es __main__.MyClass
Podría explicar lo que sucede aquí paso a paso para mí entender las razones por las cuales la recursividad sucede ?
Super() es un poco complicado con python, consulte http://rhettinger.wordpress.com/2011/05/26/super-considered-super/ – Lycha