Home > Backend Development > Python Tutorial > A detailed introduction to the functions and principles of python's super()

A detailed introduction to the functions and principles of python's super()

高洛峰
Release: 2017-03-19 15:03:03
Original
1144 people have browsed it

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)
Copy after login
>>> Foo().bar("Hello, Python.")
Hello, Python.
Copy after login

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)
Copy after login
>>> FooChild().bar("Hello, Python.")
Hello, Python.
Copy after login
Copy after login

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)
Copy after login
>>> FooChild().bar("Hello, Python.")
Hello, Python.
Copy after login
Copy after login

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()
Copy after login

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()
Copy after login

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!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template