The definition of the
Object method in Python is very weird. The first parameter is generally named self (equivalent to this in other languages), which is used to pass the object itself, while in There is no need to pass it explicitly when calling, the system will pass it automatically.
The protagonist we introduce today is super(). Super() is very commonly used in class Inheritance. It solves some problems of subclasses calling parent class methods. The problem is that the parent class is only executed once when it is called multiple times, which optimizes the execution logic. Let’s take a closer look below.
Give an example:
class Foo: def bar(self, message): print(message)
>>> Foo().bar("Hello, Python.") Hello, Python.
When there is an inheritance relationship, sometimes it is necessary to call the method of the parent class in the subclass. At this time, the simplest way is to convert the object call into a class When calling, it should be noted that the self parameter needs to be passed explicitly at this time, for example:
class FooParent: def bar(self, message): print(message) class FooChild(FooParent): def bar(self, message): FooParent.bar(self, message)
>>> FooChild().bar("Hello, Python.") Hello, Python.
This has some disadvantages. For example, if the name of the parent class is modified, multiple modifications will be involved in the subclass. In addition, Python is a language that allows multiple inheritance. The method shown above needs to be written multiple times when there is multiple inheritance, which is cumbersome. In order to solve these problems, Python introduced the super() mechanism. The example code is as follows:
class FooParent: def bar(self, message): print(message) class FooChild(FooParent): def bar(self, message): super(FooChild, self).bar(message)
>>> FooChild().bar("Hello, Python.") Hello, Python.
On the surface, the super(FooChild, self).bar(message) method and the FooParent.bar(self, message) method are The results are consistent. In fact, the internal processing mechanisms of the two methods are very different. When multiple inheritance is involved, there will be obvious differences. Let’s give an example directly:
Code 1:
class A: def init(self): print("Enter A") print("Leave A") class B(A): def init(self): print("Enter B") A.init(self) print("Leave B") class C(A): def init(self): print("Enter C") A.init(self) print("Leave C") class D(A): def init(self): print("Enter D") A.init(self) print("Leave D") class E(B, C, D): def init(self): print("Enter E") B.init(self) C.init(self) D.init(self) print("Leave E") E()
Result:
Enter E
Enter B
Enter A
Leave A
Leave B
Enter C
Enter A
Leave A
Leave C
Enter D
Enter A
Leave A
Leave D
Leave E
The execution sequence is easy to understand. The only thing that needs attention is that the public parent class A is executed multiple times.
Code 2:
class A: def init(self): print("Enter A") print("Leave A") class B(A): def init(self): print("Enter B") super(B, self).init() print("Leave B") class C(A): def init(self): print("Enter C") super(C, self).init() print("Leave C") class D(A): def init(self): print("Enter D") super(D, self).init() print("Leave D") class E(B, C, D): def init(self): print("Enter E") super(E, self).init() print("Leave E") E()
Result:
Enter E
Enter B
Enter C
Enter D
Enter A
Leave A
Leave D
Leave C
Leave B
Leave E
can be guaranteed in the super mechanism The public parent class is only executed once. As for the order of execution, it is in accordance with MRO (Method Resolution Order): method resolution order. This MRO mechanism will be introduced in detail later.
The above is the detailed content of A detailed introduction to the functions and principles of python's super(). For more information, please follow other related articles on the PHP Chinese website!