Python 类的继承

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

子类的方法__init__() 创建子类的实例时,Python首先需要完成的任务是给父类的所有属性赋值。为此,子类的方法__init__() 需要父类施以援手。

例如,下面来模拟电动汽车。电动汽车是一种特殊的汽车,因此我们可以在前面创建的Car 类的基础上创建新类ElectricCar ,这样我们就只需为电动汽车特有的属性和行为 编写代码。 下面来创建一个简单的ElectricCar 类版本,它具备Car 类的所有功能: electric_car.py

class Car():      

      """一次模拟汽车的简单尝试"""

     def __init__(self, make, model, year):

         self.make = make

         self.model = model

         self.year = year

         self.odometer_reading = 0

 

     def get_descriptive_name(self):

         long_name = str(self.year) + ' ' + self.make + ' ' + self.model
         return long_name.title()

 

     def read_odometer(self):

         print("This car has " + str(self.odometer_reading) + " miles on it.")

 

     def update_odometer(self, mileage):

         if mileage >= self.odometer_reading:

             self.odometer_reading = mileage

         else:

             print("You can't roll back an odometer!")

 

     def increment_odometer(self, miles):

         self.odometer_reading += miles

 

class ElectricCar(Car):

     """电动汽车的独特之处"""

     def __init__(self, make, model, year):

         """初始化父类的属性"""

         super().__init__(make, model, year)


my_tesla = ElectricCar('tesla', 'model s', 2016)

print(my_tesla.get_descriptive_name())


首先是Car 类的代码。创建子类时,父类必须包含在当前文件中,且位于子类前面。

我们定义了子类ElectricCar 。定义子类时,必须在括号内指定父类的 名称。

方法__init__() 接受创建Car 实例所需的信息。 处的super() 是一个特殊函数,帮助Python将父类和子类关联起来。

这行代码让Python调用ElectricCar 的父类的方法__init__() ,让ElectricCar 实例包含父类的所 有属性。

父类也称为超类(superclass),名称super因此而得名。 为测试继承是否能够正确地发挥作用,我们尝试创建一辆电动汽车,但提供的信息与创建普通汽车时相同。

我们创建ElectricCar 类的一个实例,并将其存储在变 量my_tesla 中。这行代码调用ElectricCar 类中定义的方法__init__() ,后者让Python调用父类Car 中定义的方法__init__() 。我们提供了实参'tesla' 、'model s' 和2016 。

除方法__init__() 外,电动汽车没有其他特有的属性和方法。当前,我们只想确认电动汽车具备普通汽车的行为: 2016 Tesla Model S
ElectricCar 实例的行为与Car 实例一样,现在可以开始定义电动汽车特有的属性和方法了。 

给子类定义属性和方法的方式和普通类一样,这里不再说明,此文来自《_Python编程:从入门到实践》

<think>好的,用户想了解Python继承机制及用法,特别是示例。我需要先理清继承的基本概念,然后结合示例来解释。首先,继承是面向对象编程的重要特性,允许子继承的属性和方法,这样可以实现代码重用和层次化设计。 接下来,我需要确定用户可能需要的知识点。根据提供的引用资料,Python支持单继承和多继承,还有菱形继承的问题,以及MRO(方法解析顺序)的处理方式。此外,私有属性的继承问题也需要提及,因为子不能直接访问父的私有属性,除非通过特定方式。 用户可能需要具体的代码示例,所以我应该准备单继承和多继承的例子。单继承比较简单,比如动物和狗的关系。多继承的话,可以举一个学生和员工组合成助教的例子。菱形继承问题需要展示多个父继承同一个基的情况,并说明MRO如何解决这个问题。 另外,用户提供的引用中有提到私有属性的处理,比如在父中使用双下划线定义的属性,子无法直接访问,但可以通过变形后的名称访问。这部分需要解释清楚,避免用户误解。 还要注意引用资料的标注,每个引用的内容要正确对应到回答中的相关部分。例如,引用1和2提到多重继承和语法,引用3讲菱形继承和MRO,引用4涉及私有属性的访问。 在组织内容时,先介绍继承的概念,然后逐步深入单继承、多继承、方法重写、super函数的使用,接着讨论私有属性和菱形继承问题。每个部分都要有代码示例,并解释关键点。 需要确保回答结构清晰,分点明确,让用户容易理解。同时,生成的相关问题要围绕继承机制展开,比如性能优化、应用场景等,但根据用户的问题,可能更关注用法和机制,所以相关问题可以包括多重继承的注意事项、方法重写与扩展、MRO的作用等。 最后,检查所有LaTeX格式是否正确,数学表达式用$包围,独立公式用$$。但在这个问题中可能涉及较少数学内容,主要关注代码和文字解释。确保代码块使用正确的语法,比如Python定义和方法调用。 总结一下,回答的结构大致如下: 1. 继承概念简介 2. 单继承示例 3. 多继承示例 4. 方法重写与super函数 5. 私有属性处理 6. 菱形继承与MRO 7. 相关问题 每个部分配合代码示例和引用标注,确保信息准确且易于理解。</think>### Python继承机制及用法详解 #### 一、继承基本概念 继承是面向对象编程的核心特性,允许子复用父的属性和方法,并通过扩展或修改实现新功能。Python支持单继承和多继承,使用`class 子名(父名)`语法实现[^2]。 #### 二、单继承示例 ```python class Animal: def __init__(self, name): self.name = name def speak(self): return "叫声未定义" class Dog(Animal): # 单继承Animal def speak(self): # 方法重写 return "汪汪汪" dog = Dog("阿黄") print(dog.name) # 输出: 阿黄 print(dog.speak()) # 输出: 汪汪汪 ``` #### 三、多继承示例 ```python class Student: def study(self): return "学习课程" class Employee: def work(self): return "完成工作任务" class TeachingAssistant(Student, Employee): # 多继承 def daily_task(self): return f"{self.study()} 并 {self.work()}" ta = TeachingAssistant() print(ta.daily_task()) # 输出: 学习课程 并 完成工作任务 ``` #### 四、方法重写与super函数 使用`super()`调用父方法: ```python class Parent: def show(self): print("父方法") class Child(Parent): def show(self): super().show() # 调用父方法 print("子扩展") Child().show() # 输出: # 父方法 # 子扩展 ``` #### 五、私有属性处理 双下划线开头的属性会被Python重命名: ```python class Parent: def __init__(self): self.__secret = 100 # 私有属性 class Child(Parent): def get_secret(self): # print(self.__secret) # 报错 print(self._Parent__secret) # 强制访问 Child().get_secret() # 输出:100 [^4] ``` #### 六、菱形继承与MRO Python使用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 print(D.mro()) # 输出:[D, B, C, A, object] D().test() # 输出:B [^3] ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值