Python 继承

Python继承允许子类自动获取父类的属性和方法。子类可以重写不符合其行为的父类方法,并将实例用作属性。通过重写方法,子类可以定制特定行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果你要编写的类是另一个现成类的特殊版本,可使用继承。一个类继承另一个类时,它将自动获得另一个类的所有属性和方法;原有的类称谓父类,而新类称为子类。子类除了继承父类的所有属性和方法,还可以定义自己的属性和方法。

1. 继承父类所有的属性和方法,也可以给子类定义属于自己的属性和方法,如下面例子所示

lass Restaurant: # ①
    """一次模拟餐馆的尝试"""
    def __init__(self, restaurant_name, cuisine_type):
        self.restaurant_name = restaurant_name
        self.cuisine_type = cuisine_type

    def describe_restaurant(self):
        print("The restaurant name is: " + self.restaurant_name.title() +".")
        print("The cuisine type is: " + self.cuisine_type.title() + ".")

    def open_restaurant(self):
        print(self.restaurant_name + " is openning for 24 hours.")

class IceCreamStand(Restaurant): # ②
    """冰淇淋小店的特色之处"""
    def __init__(self, restaurant_name, cuisine_type): # ③
        super().__init__(restaurant_name, cuisine_type) # ④
        self.flavors = ['strawberry', 'chocolate', "buleberry", "raspberry"] # ⑤
    def describe_flavors(self): # ⑥
        """关于利用属性self.flavors的方法"""
        print("The taste of icecreams is as fallow: ")
        for flavor in self.flavors:
            print(flavor)

favorite_shop = IceCreamStand("kfc_icecream", "sweets") # 子类IceCreamStand的实例
favorite_shop.describe_restaurant() # 调用父类的方法describe_restaurant()
favorite_shop.open_restaurant() # 调用父类的方法open_restaurant()
favorite_shop.describe_flavors() # 调用子类才有的方法describe_flavors()

# 更多的讲解
# 1. 首先是类Restaurant的代码,如(①处)。**创建子类时,父类必须包含在当前文件中,且位于子类的前面**。
# 2. 定义子类IceCreamStand 时,必须在括号内指定父类的名称。如(②处)
# 3. 方法__init__(),接收创建Restaurant实例所需的信息。 (如③ 处)
# 4. super()是一个特殊的函数,帮助python把父类和子类关联起来。在④ 处的代码,让Python调用IceCreamStand的父类的方法__init__(),让子类IceCreamStand实例包含父类的所有属性。父类也称为超类(superclass).
# 在⑤处,创建了一个新的属性,self.flavors,并设置其默认值为一个列表。根据IceCreamStand类创建的所有实例都将包含这个属性,而所有Restaurant实例都不包含它。
# 在⑥处,创建了一个使用属性self.flavors()的方法。

# 输出结果为
The restaurant name is: Kfc_Icecream.
The cuisine type is: Sweets.
kfc_icecream is openning for 24 hours.
The taste of icecreams is as fallow: 
strawberry
chocolate
buleberry
raspberry

2. 重写父类的方法

对于父类,如果它不符合子类实例的行为,都可进行重写。为此可在子类中定义一个这样的方法,即它与要重写父类的方法同名。这样,python将不会考虑这个父类的方法,而只关注你在子类中定义的相应方法。

3. 将实例用作属性,如下面的例子所示

class User: # 创建类User
    """一次模拟用户的简单尝试"""
    def __init__(self, first_name, last_name, working_place):
        """初始化属性first_name, last_name 和 working_place"""
        self.first_name = first_name
        self.last_name = last_name
        self.working_place = working_place
        self.login_attempts = 0
    def describe_user(self):
        """描述用户的基本用户信息"""
        print("The user's first name is " + self.first_name.title() + ".")
        print("The user's last name is " + self.last_name.title() + ".")
        print("The user's working place is " + self.working_place.title() + ".")
    def greet_user(self):
        """向用户打招呼"""
        print("Good morning! " + self.first_name + " " + self.last_name)
    def increment_login_attempts(self, login):
        """将属性login_attempts的值加1"""
        self.login_attempts += login
        print("当前登录的人数为 " + str(self.login_attempts))

class Privileges: # 创建类Privileges
    def __init__(self):
        self.privileges = ['can add post', 'can delete post', 'can ban user'] # ③

    def show_privileges(self):
        print("The administrator has the following privileges: ")
        for privilege in self.privileges:
            print(privilege)

class Admin(User): # 创建类Admin,该类是User类的子类
    def __init__(self, first_name, last_name, working_place):
        super().__init__(first_name, last_name, working_place)
        self.rights = Privileges() # ①

first_admin = Admin("meng", "chen", "canton") # 创建Admin的实例
first_admin.rights.show_privileges() #  ②

# 更多的解释
# 在①处,我们定义了一个名为self.rights的属性。在①处的代码让python创建一个新的Privileges实例(由于没有指定任何实参,因此使用③处指定的默认值),并将该实例存储在属性self.rights中。
# 在②处的代码让Python在实例first_admin中查找属性rights,并将存储在该属性中的Privileges实例调用方法show_privileges()。

# 输出结果为:
The administrator has the following privileges: 
can add post
can delete post
can ban user

<think>好的,用户想了解Python继承的用法和示例,以及解决继承相关的问题。首先,我需要回忆Python继承的基本概念。Python支持继承,允许子继承的属性和方法。用户可能想知道如何定义,如何调用父的方法,以及如何处理多继承等问题。 首先,我应该从基础开始,比如如何创建一个,使用super()函数调用父的方法。然后可能需要提到方法重写,这是继承中的一个重要概念,子可以覆盖父的方法。此外,Python支持多继承,这可能引发一些问题,比如菱形继承问题,需要解释MRO(方法解析顺序)如何工作。 接下来,考虑用户的实际应用场景,可能需要提供一些代码示例。比如,定义一个Animal,子Dog继承它,并重写某些方法。同时,展示super()的使用,特别是在初始化父时的应用。另外,多继承的例子,比如一个继承自两个父,说明方法解析顺序。 用户可能遇到的问题包括父方法的正确调用,多继承时的冲突,以及如何管理不同父的初始化。需要解释MRO的动态性,以及如何查看的MRO列表。此外,访问控制的问题,比如Python中没有真正的私有变量,但通过命名约定(如单下划线和双下划线)来实现封装,这可能和继承有关联。 还需要考虑引用中的内容,引用[2]和[3]提到访问修饰符,虽然Python没有严格的访问控制,但通过下划线来约定。这可能影响子对父属性和方法的访问,需要说明子如何处理这些情况。 最后,生成相关问题,帮助用户进一步学习,比如继承中的super()作用,多继承的问题,方法重写,访问控制等。确保问题覆盖用户可能遇到的常见疑问,并引导他们深入理解Python继承的机制。</think>### Python继承的用法与示例 #### 一、继承基础 Python通过`class 子名(父名)`语法实现继承。子自动获得父的属性和方法: ```python class Animal: def __init__(self, name): self.name = name def speak(self): return "未定义叫声" class Dog(Animal): def speak(self): # 方法重写 return f"{self.name}说: 汪汪!" ``` #### 二、super()函数 使用`super()`调用父方法,特别是在处理__init__时: ```python class Cat(Animal): def __init__(self, name, breed): super().__init__(name) # 调用父初始化 self.breed = breed def speak(self): base_sound = super().speak() return f"{base_sound}(实际是喵喵)" ``` #### 三、多继承与MRO Python支持多继承,方法解析顺序(MRO)遵循C3算法: ```python class A: def test(self): print("A") class B(A): def test(self): print("B") class C(A): def test(self): print("C") class D(B, C): pass D().test() # 输出B,遵循D->B->C->A顺序 print(D.mro()) # 查看方法解析顺序 ``` #### 四、访问控制 Python通过命名约定实现访问控制[^2][^3]: ```python class Parent: def __init__(self): self.public = 1 self._protected = 2 self.__private = 3 # 会重命名为_Parent__private class Child(Parent): def show(self): print(self.public) # 可访问 print(self._protected) # 约定上不直接访问 # print(self.__private) # 会报错 ``` #### 五、抽象基 使用abc模块定义抽象方法: ```python from abc import ABC, abstractmethod class Shape(ABC): @abstractmethod def area(self): pass class Circle(Shape): def __init__(self, radius): self.radius = radius def area(self): return 3.14 * self.radius ** 2 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值