Chapter 8 Python中的类

Python中的类

类是对某一些事物和情景泛化的称呼,比如狗是一个类,具体每只狗是多大,是什么品种,叫什么名字都是不一样的。那么根据类创建对象称为实例化 ,创建出来的内容就是类的实例

python 复制代码
class Dog:
    """一次模拟小狗的简单尝试"""
​
    def _init_(self, name, age):
        """初始化属性name和age"""
        self.name = name
        self.age = age
​
    def sit(self):
        """模拟小狗收到命令时坐下"""
        print(f"{self.name} is now sitting.")
​
    def roll_over(self):
        """模拟小狗收到命令时打滚"""
        print(f"{self.name} rolled over!")

__init__()方法:类中的函数叫做方法,__init__()方法是一个特殊的方法,他会在根据当前类创建新的实例的时候自动运行。这里必须注意该方法是在init前后加两个下划线,旨在避免Python默认方法与普通方法发生名称冲突。在方法的参数传值中,特别需要注意的是self,当调用与实例相关的方法的时候都会自动传入实参self,该实参指向实例自身,通过该实参可以访问该实例中的属性和方法。在创建对象的时候,给类初始化只需要传值后面的属性值,不需要传递self实参,因为self实参会自动传递。

python 复制代码
# 定义Dog类的实例
my_dog = Dog('Willie', 6)
​
print(f"My dog's name is {my_dog.name}")
print(f"My dog is {my_dog.age} years old.")

执行结果:

也可以直接调用该实例相关方法。

python 复制代码
# 调用该实例方法
my_dog.sit()
my_dog.roll_over()

执行结果:

类的初始化了解完了以后,需要了解一下如何修改类中属性的值。可以通过直接访问实例中的属性进行修改,也可以在类中定义方法,创建对象后通过该实例的方法进行修改。

python 复制代码
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 = f"{self.year} {self.make} {self.model}"
        return long_name.title()
​
    def read_odometer(self):
        """打印一条指出汽车行驶里程的消息"""
        print(f"This car has {self.odometer_reading} miles on it.")
​
    def update_odometer(self, mileage):
        self.odometer_reading = mileage
​
my_new_car = Car('audi', 'a4', 2024)
print(my_new_car.get_descriptive_name())
my_new_car.read_odometer()
​
# 通过实例属性直接赋值
my_new_car.odometer_reading = 23
my_new_car.read_odometer()
​
# 通过实例方法变更属性值
my_new_car.update_odometer(30)
my_new_car.read_odometer()

执行结果:

继承

如果要编写一个既有类的特殊版本,可以使用继承。当一个类继承另一个类的时候,将自动获得后者的所有属性和方法。原有的类称为父类,新类称为子类。子类不仅可以继承父类的所有属性和方法还可以定义自己的属性和方法。

基于上述的Car类,创建一个字类EletricCar类。

python 复制代码
class ElectricCar(Car):
    """电动汽车的独特之处"""
​
    def __init__(self, make , model, year):
        """初始化父类的属性"""
        super().__init__(make, model, year)
        self.battery_size = 40
​
    def describe_battery(self):
        """打印一条描述电池容量的消息"""
        print(f"This car has a {self.battery_size}-kWh battery.")
​
my_leaf = ElectricCar('nissan', 'leaf', 2024)
print(my_leaf.get_descriptive_name())
my_leaf.describe_battery()

执行结果:

定义子类的时候必须在括号内指定父类的名称,super()函数可以帮助调用父类的方法。

可以看到上述battery_size就是特殊属性,describe_battery()就是该子类的特殊方法。

子类中还可以实现对父类方法的重写,如果子类中定义与父类重名且形参数量相同。

python 复制代码
class ElectricCar(Car):
    """电动汽车的独特之处"""
​
    def __init__(self, make , model, year):
        """初始化父类的属性"""
        super().__init__(make, model, year)
        self.battery_size = 40
​
    def describe_battery(self):
        """打印一条描述电池容量的消息"""
        print(f"This car has a {self.battery_size}-kWh battery.")
​
    def read_odometer(self):
        """打印一条指出汽车行驶里程的消息(重写)"""
        print(f"This electric car has {self.odometer_reading} miles on it.")
​
my_leaf = ElectricCar('nissan', 'leaf', 2024)
​
my_leaf.update_odometer(40)
my_leaf.read_odometer()

执行结果:

ElectricCar类中重写了read_odometer方法。

当在类中发现添加了太多的细节,属性和方法越来越多,这个时候可以将其中一部分提取出来作为一个独立的类。将一个大型的类拆分成多个小类,这种方法叫做组合。接下来结合上面写一个完整的例子:

python 复制代码
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 = f"{self.year} {self.make} {self.model}"
        return long_name.title()
​
    def read_odometer(self):
        """打印一条指出汽车行驶里程的消息"""
        print(f"This car has {self.odometer_reading} miles on it.")
​
    def update_odometer(self, mileage):
        self.odometer_reading = mileage
​
class Battery:
    def __init__(self, battery_size=40):
        """初始化电池的属性"""
        self.battery_size = battery_size
​
    def describe_battery(self):
        print(f"This car has a {self.battery_size}-kWh battery.")
​
class ElectricCar(Car):
    """电动汽车的独特"""
​
    def __init__(self, make, model, year):
        """
        先初始化父类的属性,再初始化电动汽车特有的属性
        """
        super().__init__(make, model, year)
        self.battery = Battery()
​
my_leaf = ElectricCar('nissan', 'leaf', 2024)
print(my_leaf.get_descriptive_name())
my_leaf.battery.describe_battery()

执行结果:

相关推荐
m0_734949791 天前
MySQL如何配置定时清理过期备份文件_find命令与保留周期策略
jvm·数据库·python
m0_514520571 天前
MySQL索引优化后性能没提升_通过EXPLAIN查看索引命中率
jvm·数据库·python
H Journey1 天前
Python 国内pip install 安装缓慢
python·pip·install 加速
Polar__Star1 天前
如何在 AWS Lambda 中正确使用临时凭证生成 S3 预签名 URL
jvm·数据库·python
m0_743623921 天前
React 自定义 Hook 的命名规范与调用规则详解
jvm·数据库·python
FreakStudio1 天前
无硬件学LVGL—定时器篇:基于Web模拟器+MicroPython速通GUI开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
gCode Teacher 格码致知1 天前
Python提高:pytest的简单案例-由Deepseek产生
python·pytest
不要秃头的小孩1 天前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
科雷软件测试1 天前
使用python+Midscene.js AI驱动打造企业级WEB自动化解决方案
前端·javascript·python
星越华夏1 天前
python——三角函数用法
开发语言·python