Взгляните на это.
Обратите внимание, что класс B
переопределяет метод A
a()
.
In [1]: class A(object):
...: def __init__(self):
...: self.a()
...: def a(self):
...: print "A.a()"
...:
...:
In [2]: class B(A):
...: def __init__(self):
...: super(B, self).__init__()
...: def a(self):
...: print "B.a()"
...:
...:
In [3]: b = B()
B.a()
Никаких сюрпризов нет.
Теперь взглянем на это.
Обратите внимание, что метод, который теперь переопределяется, __a()
.
In [7]: class A(object):
...: def __init__(self):
...: self.__a()
...: def __a(self):
...: print "A.__a()"
...:
...:
In [8]: class B(A):
...: def __init__(self):
...: super(B, self).__init__()
...: def __a(self):
...: print "B.__a()"
...:
...:
In [9]: b = B()
A.__a()
Этот тип меня удивил.
Может кто-нибудь объяснить, почему A.__a()
вызывается вместо B.__a()
?
Что-нибудь __special__
около __a
?
Обновление: После прочтения ответа Шона мне хотелось узнать, могу ли я переопределить метод, названный mangled, и получил этот результат:
In [11]: class B(A):
....: def __init__(self):
....: super(B, self).__init__()
....: def _A__a(self):
....: print "B._A__a()"
....:
....:
In [12]: b = B()
B._A__a()