Hướng dẫn super() in python class - super () trong lớp python

Xem bây giờ hướng dẫn này có một khóa học video liên quan được tạo bởi nhóm Python thực sự. Xem nó cùng với hướng dẫn bằng văn bản để hiểu sâu hơn về sự hiểu biết của bạn: siêu tải các lớp của bạn với Python Super () This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Supercharge Your Classes With Python super() This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Supercharge Your Classes With Python super()

Show

Nội dung chính ShowShow

  • Tổng quan về chức năng Python từ >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9
  • >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9 trong một kế thừa duy nhất
  • Trong ví dụ này, class Rectangle: def __init__(self, length, width): self.length = length self.width = width def area(self): return self.length * self.width def perimeter(self): return 2 * self.length + 2 * self.width # Here we declare that the Square class inherits from the Rectangle class class Square(Rectangle): def __init__(self, length): super().__init__(length, length) 9 là siêu lớp và >>> square = Square(4) >>> square.area() 16 0 là lớp con.
  • Một lần lặn sâu >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9
  • >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9 trong nhiều kế thừa
  • Tổng quan về kế thừa
  • Thứ tự phân giải phương pháp
  • Tuy nhiên, vẫn còn một vấn đề ở đây. Để đơn giản, tôi đã làm một vài điều sai trong ví dụ này: lần đầu tiên và quan trọng nhất là tôi có hai lớp riêng biệt với cùng tên và chữ ký phương thức.
  • Một bản tóm tắt >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9
  • Super () __ init__ làm gì?
  • Tại sao Super được sử dụng trong lớp?
  • Siêu lớp của mỗi lớp trong Python là gì?

Mặc dù Python không phải là ngôn ngữ hướng đối tượng, nhưng nó đủ linh hoạt và đủ mạnh để cho phép bạn xây dựng các ứng dụng của mình bằng mô hình hướng đối tượng. Một trong những cách mà Python đạt được điều này là bằng cách hỗ trợ thừa kế, mà nó làm với

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9.inheritance, which it does with
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9.inheritance, which it does with
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9.

Trong hướng dẫn này, bạn sẽ tìm hiểu về những điều sau đây:

  • Khái niệm thừa kế trong Python
  • Nhiều kế thừa trong Python
  • Hàm
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    9 hoạt động như thế nào
  • Làm thế nào chức năng
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    9 trong một kế thừa duy nhất hoạt động
  • Làm thế nào chức năng
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    9 trong nhiều kế thừa hoạt động

Tổng quan về chức năng Python từ >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9

Nếu bạn có kinh nghiệm với các ngôn ngữ hướng đối tượng, bạn có thể đã quen thuộc với chức năng của

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9.

Nếu không, đừng sợ! Mặc dù tài liệu chính thức khá kỹ thuật, nhưng ở cấp độ cao

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 cho phép bạn truy cập vào các phương thức trong một siêu lớp từ lớp con kế thừa từ nó.
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 Một mình trả về một đối tượng tạm thời của siêu lớp sau đó cho phép bạn gọi các phương thức siêu lớp đó.

Tại sao bạn muốn làm bất kỳ điều này? Mặc dù các khả năng bị giới hạn bởi trí tưởng tượng của bạn, một trường hợp sử dụng phổ biến là xây dựng các lớp mở rộng chức năng của các lớp được xây dựng trước đó.

Gọi các phương thức được xây dựng trước đó với

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 giúp bạn không cần viết lại các phương thức đó trong lớp con của bạn và cho phép bạn trao đổi các lớp học với các thay đổi mã tối thiểu.

>>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9 trong một kế thừa duy nhất

Trong ví dụ này, class Rectangle: def __init__(self, length, width): self.length = length self.width = width def area(self): return self.length * self.width def perimeter(self): return 2 * self.length + 2 * self.width # Here we declare that the Square class inherits from the Rectangle class class Square(Rectangle): def __init__(self, length): super().__init__(length, length) 9 là siêu lớp và >>> square = Square(4) >>> square.area() 16 0 là lớp con.inheritance might be an unfamiliar term. Inheritance is a concept in object-oriented programming in which a class derives (or inherits) attributes and behaviors from another class without needing to implement them again.

Một lần lặn sâu >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9

class Rectangle:
    def __init__(self, length, width):
        self.length = length
        self.width = width

    def area(self):
        return self.length * self.width

    def perimeter(self):
        return 2 * self.length + 2 * self.width

class Square:
    def __init__(self, length):
        self.length = length

    def area(self):
        return self.length * self.length

    def perimeter(self):
        return 4 * self.length

>>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9 trong nhiều kế thừa

Tổng quan về kế thừa

Thứ tự phân giải phương pháp

Tuy nhiên, vẫn còn một vấn đề ở đây. Để đơn giản, tôi đã làm một vài điều sai trong ví dụ này: lần đầu tiên và quan trọng nhất là tôi có hai lớp riêng biệt với cùng tên và chữ ký phương thức.

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

Một bản tóm tắt >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9

Super () __ init__ làm gì?

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

0

Tại đây, bạn đã sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 để gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

12 của lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09, cho phép bạn sử dụng nó trong lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 mà không cần lặp lại mã. Dưới đây, chức năng cốt lõi vẫn còn sau khi thực hiện các thay đổi:

>>>

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

1

Trong ví dụ này, bạn có hai hình dạng có liên quan với nhau: một hình vuông là một loại hình chữ nhật đặc biệt. Tuy nhiên, mã không phản ánh mối quan hệ đó và do đó có mã về cơ bản được lặp lại.

Bằng cách sử dụng kế thừa, bạn có thể giảm số lượng mã bạn viết đồng thời phản ánh mối quan hệ trong thế giới thực giữa hình chữ nhật và hình vuông:

Tại đây, bạn đã sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 để gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

12 của lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09, cho phép bạn sử dụng nó trong lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 mà không cần lặp lại mã. Dưới đây, chức năng cốt lõi vẫn còn sau khi thực hiện các thay đổi:inherited
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

3 9 from the
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09 class.inherited
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

3 9 from the
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09 class.

Trong ví dụ này, class Rectangle: def __init__(self, length, width): self.length = length self.width = width def area(self): return self.length * self.width def perimeter(self): return 2 * self.length + 2 * self.width # Here we declare that the Square class inherits from the Rectangle class class Square(Rectangle): def __init__(self, length): super().__init__(length, length) 9 là siêu lớp và >>> square = Square(4) >>> square.area() 16 0 là lớp con.

Bởi vì các phương thức

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

19 rất giống nhau, bạn chỉ cần gọi phương thức siêu lớp ____ ____39 (
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

31) từ phương thức của
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 bằng cách sử dụng
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9. Điều này đặt các thuộc tính
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

34 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

35 mặc dù bạn chỉ phải cung cấp một tham số
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

36 duy nhất cho hàm tạo
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10.

Khi bạn chạy điều này, mặc dù lớp

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 của bạn không thực hiện rõ ràng nó, cuộc gọi đến
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 sẽ sử dụng phương thức
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 trong siêu lớp và in
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

81. Lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 được kế thừa
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 từ lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09.
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 có thể làm gì cho bạn?
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

3

Vậy

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 có thể làm gì cho bạn trong một kế thừa duy nhất?

>>>

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

8

Trong ví dụ này, bạn có hai hình dạng có liên quan với nhau: một hình vuông là một loại hình chữ nhật đặc biệt. Tuy nhiên, mã không phản ánh mối quan hệ đó và do đó có mã về cơ bản được lặp lại.

Bằng cách sử dụng kế thừa, bạn có thể giảm số lượng mã bạn viết đồng thời phản ánh mối quan hệ trong thế giới thực giữa hình chữ nhật và hình vuông:

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 để gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

12 của lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09, cho phép bạn sử dụng nó trong lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 mà không cần lặp lại mã. Dưới đây, chức năng cốt lõi vẫn còn sau khi thực hiện các thay đổi:inherited
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

3 9 from the
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09 class.

Trong ví dụ này, class Rectangle: def __init__(self, length, width): self.length = length self.width = width def area(self): return self.length * self.width def perimeter(self): return 2 * self.length + 2 * self.width # Here we declare that the Square class inherits from the Rectangle class class Square(Rectangle): def __init__(self, length): super().__init__(length, length) 9 là siêu lớp và >>> square = Square(4) >>> square.area() 16 0 là lớp con.

Bởi vì các phương thức

>>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 10 và >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 09 >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 19 rất giống nhau, bạn chỉ cần gọi phương thức siêu lớp ____ ____39 (>>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 31) từ phương thức của >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 10 bằng cách sử dụng >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9. Điều này đặt các thuộc tính >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 34 và >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 35 mặc dù bạn chỉ phải cung cấp một tham số >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 36 duy nhất cho hàm tạo >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 10.

Khi bạn chạy điều này, mặc dù lớp

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9.

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 của bạn không thực hiện rõ ràng nó, cuộc gọi đến
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 sẽ sử dụng phương thức
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 trong siêu lớp và in
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

81. Lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 được kế thừa
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 từ lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09.
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 có thể làm gì cho bạn?
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

3

Vậy

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 có thể làm gì cho bạn trong một kế thừa duy nhất?

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

2

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 Trả về một đối tượng đại biểu cho lớp cha, vì vậy bạn gọi phương thức bạn muốn trực tiếp trên nó:
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

78.

Điều này không chỉ giúp chúng tôi không phải viết lại các tính toán khu vực mà còn cho phép chúng tôi thay đổi logic

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 bên trong ở một vị trí duy nhất. Điều này đặc biệt có ích khi bạn có một số lớp con kế thừa từ một siêu lớp.

Một lần lặn sâu >>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9

Trước khi đi vào nhiều kế thừa, hãy để Lừa đi đường vòng nhanh vào cơ chế của

Mặc dù các ví dụ ở trên (và bên dưới) gọi

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 mà không có bất kỳ tham số nào,
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 cũng có thể lấy hai tham số: thứ nhất là lớp con và tham số thứ hai là một đối tượng là một thể hiện của lớp con đó.

Đầu tiên, hãy để xem hai ví dụ cho thấy thao tác mà biến đầu tiên có thể làm, sử dụng các lớp đã được hiển thị:

Trong Python 3, cuộc gọi

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

34 tương đương với cuộc gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 không tham số. Tham số đầu tiên đề cập đến lớp con
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10, trong khi tham số thứ hai đề cập đến một đối tượng
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10, trong trường hợp này là
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

38. Bạn cũng có thể gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 với các lớp khác:
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

7bound method: a method that is bound to the object, which gives the method the object’s context such as any instance attributes. If this parameter is not included, the method returned is just a function, unassociated with an object’s context.

Để biết thêm thông tin về các phương thức bị ràng buộc, các phương thức và chức năng không liên kết, hãy đọc tài liệu Python trên hệ thống mô tả của nó.

>>> square = Square(4) >>> square.area() 16 >>> rectangle = Rectangle(2,4) >>> rectangle.area() 8 9 trong nhiều kế thừa

Bây giờ, bạn đã làm việc thông qua một cái nhìn tổng quan và một số ví dụ về

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 và kế thừa đơn lẻ, bạn sẽ được giới thiệu để xem tổng quan và một số ví dụ sẽ chứng minh cách thức hoạt động của nhiều kế thừa và cách
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 cho phép chức năng đó.

Tổng quan về kế thừa

Có một trường hợp sử dụng khác trong đó

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 thực sự tỏa sáng, và trường hợp này không phổ biến như kịch bản thừa kế duy nhất. Ngoài sự thừa kế duy nhất, Python còn hỗ trợ nhiều kế thừa, trong đó một lớp con có thể kế thừa từ nhiều lớp siêu cấp mà don don nhất thiết phải kế thừa với nhau (còn được gọi là các lớp anh chị em).sibling classes). sibling classes).

Tôi là một người rất trực quan và tôi thấy các sơ đồ rất hữu ích để hiểu các khái niệm như thế này. Hình ảnh dưới đây cho thấy một kịch bản kế thừa rất đơn giản, trong đó một lớp kế thừa từ hai siêu lớp không liên quan (anh chị em):

Một ví dụ được ghi lại của nhiều kế thừa (hình ảnh: Kyle Stratis)

Để minh họa tốt hơn nhiều kế thừa trong hành động, đây là một số mã để bạn thử, cho thấy cách bạn có thể xây dựng một kim tự tháp bên phải (một kim tự tháp có cơ sở vuông) ra khỏi

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10:
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

3

Ví dụ này tuyên bố một lớp

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08 và lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

11 kế thừa từ cả
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08.

Bạn sẽ thấy một phương pháp

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 khác sử dụng
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 giống như trong một kế thừa duy nhất, với mục đích của nó đạt đến các phương thức
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

16 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 được xác định tất cả các cách trong lớp
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

09.

Tuy nhiên, vấn đề là cả hai lớp siêu (

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10) xác định A
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39. Dành một giây và suy nghĩ về những gì có thể xảy ra khi bạn gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 vào
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

11, và sau đó thử gọi nó như bên dưới:

>>>

class Rectangle:
    def __init__(self, length, width):
        self.length = length
        self.width = width

    def area(self):
        return self.length * self.width

    def perimeter(self):
        return 2 * self.length + 2 * self.width

class Square:
    def __init__(self, length):
        self.length = length

    def area(self):
        return self.length * self.length

    def perimeter(self):
        return 4 * self.length
4

Bạn có đoán rằng Python sẽ cố gắng gọi

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

24 không? Điều này là do một thứ gọi là thứ tự phân giải phương thức.method resolution order.method resolution order.

Thứ tự phân giải phương pháp

Thứ tự độ phân giải phương thức (hoặc MRO) cho Python biết cách tìm kiếm các phương thức kế thừa. Điều này có ích khi bạn sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 vì MRO cho bạn biết chính xác nơi Python sẽ tìm kiếm một phương pháp mà bạn gọi với
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 và theo thứ tự nào.MRO) tells Python how to search for inherited methods. This comes in handy when you’re using
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 because the MRO tells you exactly where Python will look for a method you’re calling with
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 and in what order.MRO) tells Python how to search for inherited methods. This comes in handy when you’re using
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 because the MRO tells you exactly where Python will look for a method you’re calling with
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 and in what order.

Mỗi lớp có một thuộc tính

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

27 cho phép chúng tôi kiểm tra đơn hàng, vì vậy hãy để Lừa làm điều đó:

>>>

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

0

Bạn có đoán rằng Python sẽ cố gắng gọi

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

24 không? Điều này là do một thứ gọi là thứ tự phân giải phương thức.method resolution order.

Thứ tự phân giải phương pháp

Thứ tự độ phân giải phương thức (hoặc MRO) cho Python biết cách tìm kiếm các phương thức kế thừa. Điều này có ích khi bạn sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 vì MRO cho bạn biết chính xác nơi Python sẽ tìm kiếm một phương pháp mà bạn gọi với
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 và theo thứ tự nào.MRO) tells Python how to search for inherited methods. This comes in handy when you’re using
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 because the MRO tells you exactly where Python will look for a method you’re calling with
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 and in what order.

Mỗi lớp có một thuộc tính

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

27 cho phép chúng tôi kiểm tra đơn hàng, vì vậy hãy để Lừa làm điều đó:

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

24 không? Điều này là do một thứ gọi là thứ tự phân giải phương thức.

Vấn đề ở đây là thông dịch viên đang tìm kiếm

>>>

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

2

Bạn có đoán rằng Python sẽ cố gắng gọi

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

24 không? Điều này là do một thứ gọi là thứ tự phân giải phương thức.method resolution order.

Thứ tự phân giải phương pháp

Thứ tự độ phân giải phương thức (hoặc MRO) cho Python biết cách tìm kiếm các phương thức kế thừa. Điều này có ích khi bạn sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 vì MRO cho bạn biết chính xác nơi Python sẽ tìm kiếm một phương pháp mà bạn gọi với
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 và theo thứ tự nào.MRO) tells Python how to search for inherited methods. This comes in handy when you’re using
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 because the MRO tells you exactly where Python will look for a method you’re calling with
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 and in what order.

Mỗi lớp có một thuộc tính

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

27 cho phép chúng tôi kiểm tra đơn hàng, vì vậy hãy để Lừa làm điều đó:cooperate. Part of this is ensuring that your methods are unique so that they get resolved in the MRO, by making sure method signatures are unique—whether by using method names or method parameters.

Trong trường hợp này, để tránh một cuộc đại tu hoàn chỉnh của mã của bạn, bạn có thể đổi tên phương thức

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08 Lớp ____ ____49 thành
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

55. Bằng cách này, các phương thức khu vực có thể tiếp tục sử dụng các thuộc tính lớp thay vì lấy các tham số bên ngoài:
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

3

Hãy cùng tiếp tục và sử dụng điều này trong lớp

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

11:
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

4

Vấn đề tiếp theo ở đây là mã không có đối tượng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08 được ủy quyền giống như đối tượng
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10, do đó, việc gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

59 sẽ cung cấp cho chúng tôi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

42 kể từ
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

41 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

40 don don có bất kỳ giá trị nào.

Bạn cần phải làm hai điều để khắc phục điều này:

  1. Tất cả các phương thức được gọi với

    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    9 cần phải có một cuộc gọi đến phiên bản siêu lớp của họ của phương thức đó. Điều này có nghĩa là bạn sẽ cần thêm
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    64 vào các phương thức
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    19 của
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    08 và
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    09.
  2. Thiết kế lại tất cả các cuộc gọi

    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    19 để lấy từ điển từ khóa. Xem mã hoàn chỉnh bên dưới.
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

5

Có một số khác biệt quan trọng trong mã này:

  • ** ________ 169 được sửa đổi ở một số nơi (chẳng hạn như ________ 170): ** Điều này sẽ cho phép người dùng của các đối tượng này chỉ khởi động chúng bằng các đối số có ý nghĩa đối với đối tượng cụ thể đó.

  • Thiết lập các đối số được đặt tên trước

    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    4371: Bạn có thể thấy điều này trong
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    70. Điều này có tác dụng gọn gàng của việc bật chìa khóa đó ra khỏi từ điển
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    71, do đó đến khi kết thúc vào cuối MRO trong lớp
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    32,
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    71 trống rỗng. You can see this in 71: Bạn có thể thấy điều này trong
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    70. Điều này có tác dụng gọn gàng của việc bật chìa khóa đó ra khỏi từ điển
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    71, do đó đến khi kết thúc vào cuối MRO trong lớp
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    32,
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    71 trống rỗng.
    You can see this in

    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    70. This has the neat effect of popping that key right out of the
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    71 dictionary, so that by the time that it ends up at the end of the MRO in the
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    32 class,
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    71 is empty.

Bây giờ, khi bạn sử dụng các lớp được cập nhật này, bạn có cái này:

>>>

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

6

Bạn thấy rằng MRO bây giờ là những gì bạn mong đợi, và bạn cũng có thể kiểm tra khu vực của kim tự tháp, nhờ

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

16.

Tuy nhiên, vẫn còn một vấn đề ở đây. Để đơn giản, tôi đã làm một vài điều sai trong ví dụ này: lần đầu tiên và quan trọng nhất là tôi có hai lớp riêng biệt với cùng tên và chữ ký phương thức.

Điều này gây ra các vấn đề với độ phân giải phương thức, bởi vì trường hợp đầu tiên của

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 gặp phải trong danh sách MRO sẽ được gọi.

Khi bạn sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 với nhiều kế thừa, điều bắt buộc phải thiết kế các lớp học của bạn để hợp tác. Một phần của điều này là đảm bảo rằng các phương thức của bạn là duy nhất để chúng được giải quyết trong MRO, bằng cách đảm bảo chữ ký phương thức là duy nhất cho dù bằng cách sử dụng tên phương thức hoặc tham số phương thức.composition instead of inheritance. Since this article is focused on inheritance, I won’t go into too much detail on composition and how to wield it in Python. Luckily, Real Python has published a deep-dive guide to both inheritance and composition in Python that will make you an OOP pro in no time. composition instead of inheritance. Since this article is focused on inheritance, I won’t go into too much detail on composition and how to wield it in Python. Luckily, Real Python has published a deep-dive guide to both inheritance and composition in Python that will make you an OOP pro in no time.

Trong trường hợp này, để tránh một cuộc đại tu hoàn chỉnh của mã của bạn, bạn có thể đổi tên phương thức

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08 Lớp ____ ____49 thành
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

55. Bằng cách này, các phương thức khu vực có thể tiếp tục sử dụng các thuộc tính lớp thay vì lấy các tham số bên ngoài:mixin. mixin.

Hãy cùng tiếp tục và sử dụng điều này trong lớp

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

11:

Vấn đề tiếp theo ở đây là mã không có đối tượng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

08 được ủy quyền giống như đối tượng
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

10, do đó, việc gọi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

59 sẽ cung cấp cho chúng tôi
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

42 kể từ
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

41 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

40 don don có bất kỳ giá trị nào.

Bạn cần phải làm hai điều để khắc phục điều này:

Tất cả các phương thức được gọi với

>>>

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

8

Bạn thấy rằng MRO bây giờ là những gì bạn mong đợi, và bạn cũng có thể kiểm tra khu vực của kim tự tháp, nhờ

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 và
>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

16.

Tuy nhiên, vẫn còn một vấn đề ở đây. Để đơn giản, tôi đã làm một vài điều sai trong ví dụ này: lần đầu tiên và quan trọng nhất là tôi có hai lớp riêng biệt với cùng tên và chữ ký phương thức.

Điều này gây ra các vấn đề với độ phân giải phương thức, bởi vì trường hợp đầu tiên của

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

39 gặp phải trong danh sách MRO sẽ được gọi.

Khi bạn sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9 với nhiều kế thừa, điều bắt buộc phải thiết kế các lớp học của bạn để hợp tác. Một phần của điều này là đảm bảo rằng các phương thức của bạn là duy nhất để chúng được giải quyết trong MRO, bằng cách đảm bảo chữ ký phương thức là duy nhất cho dù bằng cách sử dụng tên phương thức hoặc tham số phương thức.composition instead of inheritance. Since this article is focused on inheritance, I won’t go into too much detail on composition and how to wield it in Python. Luckily, Real Python has published a deep-dive guide to both inheritance and composition in Python that will make you an OOP pro in no time.

Để biết thêm thông tin về lập trình hướng đối tượng trong Python và sử dụng

>>> square = Square(4)
>>> square.area()
16
>>> rectangle = Rectangle(2,4)
>>> rectangle.area()
8

9, hãy xem các tài nguyên này:
  • Tài liệu chính thức
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    9
  • Python sườn
    >>> square = Square(4)
    >>> square.area()
    16
    >>> rectangle = Rectangle(2,4)
    >>> rectangle.area()
    8
    
    
    9 được coi là siêu
  • Lập trình hướng đối tượng trong Python 3

Xem bây giờ hướng dẫn này có một khóa học video liên quan được tạo bởi nhóm Python thực sự. Xem nó cùng với hướng dẫn bằng văn bản để hiểu sâu hơn về sự hiểu biết của bạn: siêu tải các lớp của bạn với Python Super () This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Supercharge Your Classes With Python super() This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Supercharge Your Classes With Python super()

Super () __ init__ làm gì?

Hiểu python Super () với các phương thức __init __ () khi phương thức này được gọi là nó cho phép lớp khởi tạo các thuộc tính của lớp.Trong một lớp con được kế thừa, một lớp cha có thể được giới thiệu với việc sử dụng hàm Super ().allows the class to initialize the attributes of the class. In an inherited subclass, a parent class can be referred with the use of the super() function.allows the class to initialize the attributes of the class. In an inherited subclass, a parent class can be referred with the use of the super() function.

Tại sao Super được sử dụng trong lớp?

Từ khóa siêu đề cập đến các đối tượng siêu lớp (cha mẹ).Nó được sử dụng để gọi các phương thức siêu lớp và để truy cập vào hàm tạo siêu lớp.Việc sử dụng phổ biến nhất của Super Keyword là loại bỏ sự nhầm lẫn giữa các lớp học và các lớp con có các phương thức có cùng tên.to eliminate the confusion between superclasses and subclasses that have methods with the same name.to eliminate the confusion between superclasses and subclasses that have methods with the same name.

Siêu lớp của mỗi lớp trong Python là gì?

Lớp mà một lớp kế thừa được gọi là cha mẹ hoặc siêu lớp.Một lớp kế thừa từ một siêu lớp được gọi là một lớp con, còn được gọi là lớp người thừa kế hoặc lớp con.Siêu lớp đôi khi được gọi là tổ tiên là tốt.. A class which inherits from a superclass is called a subclass, also called heir class or child class. Superclasses are sometimes called ancestors as well.. A class which inherits from a superclass is called a subclass, also called heir class or child class. Superclasses are sometimes called ancestors as well.