python 中面向对象编程:深入理解封装、继承和多态

news2024/10/5 15:26:37

在本章中,我们将深入探讨Python中的高级面向对象编程概念,包括封装、继承和多态。让我们开始吧!

目录

    • 面向对象简介
      • 类和实例
      • 属性和方法
      • 继承和多态
    • 高级面向对象概念
      • 私有变量
      • 使用 `@property`
      • 使用 `__slots__`
      • 类的特殊成员
        • `__doc__`
        • `__call__`
        • `__str__`
        • `__iter__`
        • `__getitem__`, `__setitem__`, `__delitem__`

面向对象简介

面向对象编程(OOP)是一种编程范式,它通过将数据和方法封装在对象中,使代码更加模块化和易于管理。通过这种方式,我们可以避免重复造轮子,提升代码的可维护性和可读性。
image.png

类和实例

在OOP中,类是对某类对象的抽象,而实例是类的具体对象。例如,我们可以定义一个Human类来抽象表示人,并通过实例化该类来创建具体的人对象。

class Human:
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def hello(self):
        print(f"Hello, I'm {self.name}")

person1 = Human("Yingshan", 25)
person2 = Human(name="Lee", age=23)

person1.hello()  # 输出: Hello, I'm Yingshan
person2.hello()  # 输出: Hello, I'm Lee

image.png

属性和方法

类的属性是类中定义的数据,而方法是类中定义的函数。在上面的例子中,nameage是属性,hello是方法。
image.png

继承和多态

继承是OOP的核心概念之一,通过继承,我们可以创建一个新类,该类继承自现有的类,获得其所有属性和方法。例如,我们可以创建一个Animal类,然后让Human类继承自Animal类。
image.png

class Animal:
    def mobile(self):
        return "Yes, animals are mobile"

class Human(Animal):
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def hello(self):
        print(f"Hello, I'm {self.name}")

human = Human("Yingshan", 25)
print(human.mobile())  # 输出: Yes, animals are mobile

多态允许我们通过父类引用来调用子类的方法。在Python中,这可以通过方法重写实现。例如:

class Animal:
    def mobile(self):
        return "Yes, this animal is mobile"

class Human(Animal):
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def hello(self):
        print(f"Hello, I'm {self.name}")

    def mobile(self):
        return "Yes, this person is mobile"

human = Human("Yingshan", 25)
print(human.mobile())  # 输出: Yes, this person is mobile

高级面向对象概念

私有变量

在类中,通过在变量名前加双下划线,可以将变量设为私有变量,仅在类内部访问。

class Person:
    def __init__(self, name):
        self.__name = name

    def get_name(self):
        return self.__name

person = Person("XiaoYang")
print(person.get_name())  # 输出: XiaoYang
# print(person.__name)  # 会报错,无法直接访问私有变量

使用 @property

使用 @property 装饰器,我们可以将方法转换为属性,从而更自然地访问和修改类的属性。
image.png

class Person:
    def __init__(self, weight):
        self.__weight = weight

    @property
    def weight(self):
        return self.__weight

    @weight.setter
    def weight(self, value):
        if value < 100:
            print("Too light!")
        elif value > 400:
            print("Too heavy!")
        else:
            self.__weight = value

p1 = Person(160)
print(p1.weight)  # 输出: 160
p1.weight = 450   # 输出: Too heavy!

使用 __slots__

为了限制实例的属性,我们可以使用 __slots__。这可以节省内存空间。
image.png

class Person:
    __slots__ = ('name', 'country')

p1 = Person()
p1.name = "XiaoYang"
p1.country = "China"
# p1.weight = 160  # 会报错,`weight` 不在 `__slots__` 中

类的特殊成员

__doc__

__doc__ 表示类的文档字符串。

class Person:
    """
    This is a person class.
    """
    def __init__(self, name):
        self.__name = name

print(Person.__doc__)
__call__

通过定义 __call__ 方法,可以使对象变得可调用。

class Person:
    def __init__(self, name):
        self.__name = name

    def __call__(self):
        print("Calling myself")

yingshan = Person("Yingshan")
yingshan()  # 输出: Calling myself
__str__

__str__ 方法定义了对象的字符串表示。

class Person:
    def __init__(self, name):
        self.__name = name

    def __str__(self):
        return f"This is {self.__name}"

yingshan = Person("Yingshan")
print(yingshan)  # 输出: This is Yingshan
__iter__

通过定义 __iter__ 方法,可以将对象变为可迭代。

class Person:
    def __init__(self, names):
        self.__names = names

    def __iter__(self):
        return iter(self.__names)

friends = Person(["Yingshan", "Mike", "Tim"])
for friend in friends:
    print(friend)  # 依次输出: Yingshan, Mike, Tim
__getitem__, __setitem__, __delitem__

这些方法用于索引操作。

class Person:
    def __init__(self):
        self.dic = {}

    def __setitem__(self, key, value):
        self.dic[key] = value

    def __getitem__(self, key):
        return self.dic[key]

    def __delitem__(self, key):
        del self.dic[key]

obj = Person()
obj["name"] = "Yingshan"
print(obj["name"])  # 输出: Yingshan
del obj["name"]

通过面向对象编程,复杂的问题变得更易于解决。

希望这篇文章能帮助你更好地理解Python中的面向对象编程。Happy coding!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1866824.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何用Vue3打造一个交互式待办事项列表和日历

本文由ScriptEcho平台提供技术支持 项目地址&#xff1a;传送门 构建交互式卡片组件&#xff1a;Vue.js 实战 应用场景介绍 在现代 Web 应用程序中&#xff0c;卡片组件无处不在&#xff0c;它们提供了一种灵活且可扩展的方式来展示信息和启用交互。本文将指导你使用 Vue.j…

Qt 学习(一) addressbook

Qt Demo: addressbook (1)创建项目&#xff1a;选择不创建界面&#xff0c;即UI&#xff0c;此时会自动生成的文件如图所示&#xff1a; QApplication&#xff1a; MainWindow 继承自 QMainWindow&#xff0c;根据需要设计的界面样式。 (2)确定MainWindow 的成员变量 首先&…

20240626(周三)AH股行情总结:沪指午后大反弹,港股震荡走高,AIGC、短剧概念走强,低价可转债触底反弹

内容提要 上证指数午后大反弹&#xff0c;创业板指涨近2%。港股震荡走高&#xff0c;恒生科技指数涨近1%。AIGC概念领涨&#xff0c;ST股、贵金属板块领跌。低价可转债集体大涨&#xff0c;广汇转债涨20%触发临停&#xff0c;广汇汽车今日上演地天板。 周三&#xff0c;A股午…

【BUG记录】条件查询没有查询结果 || MybatisPlus打印查询语句

结论 先说结论&#xff0c;查询没有结果&#xff0c;可能是数据库连接&#xff0c;数据问题之类&#xff0c;最有可能的根本原因是查询语句问题&#xff0c;需要想办法检查查询语句&#xff0c;使用mybatisPlus等自动生成查询语句的框架不能直接看语句&#xff0c;可以依靠日志…

Python期末模拟题库[python123题库]

期末模拟题库 一、单项选择题 1、下列关于Python语言的特点的说法中&#xff0c;错误的是()‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪…

高效运维:标准化与智能化的运维流程管理实践

高效运维&#xff1a;标准化与智能化的运维流程管理实践 在信息化建设日益深化的今天&#xff0c;运维流程管理已成为企业确保其信息系统稳定、高效运行的关键手段。通过系统化、标准化的运维流程管理&#xff0c;企业能够有效预防系统故障&#xff0c;提升服务质量&#xff0…

数据结构 —— 二叉树

1.树的概念及结构 1.1树的概念 树是一种非线性的数据结构&#xff0c;它有着多分支&#xff0c;层次性的特点。 由于其形态类似于自然界中倒过来的数&#xff0c;所以我们将这种数据结构称为“树形结构” 注意&#xff1a; 树形结构中&#xff0c;子树之间不能有交集&#x…

一加全机型TWRP合集/橙狐recovery下载-20240603更新-支持一加12/Ace3V手机

TWRP是目前安卓平台的刷机神器&#xff0c;可快速刷写第三方ROM或官方系统&#xff0c;刷入TWRP之前需要解锁BL&#xff0c;目前已适配一加多个机型。ROM乐园小编20240603整理&#xff0c;涵盖一加1到一加Ace3V多机型专用TWRP文件&#xff0c;个人机型橙狐recovery适配相对完整…

MySQL 8 命令安装卸载教程

一、下载MySQL8 下载连接 MySQL :: Download MySQL Community Server 我下载的是当前最新版8.4 二、安装 1.解压 解压到需要安装的位置&#xff0c;例如我的位置&#xff1a; 2.创建配置文件 新建文本文档&#xff0c;复制下面配置文件&#xff08;注意修改路经&#xff09;…

DPDK使用make编译并运行示例程序

环境&#xff1a; VMware Workstation 16 Pro 16.2.4 虚拟机系统&#xff1a;Centos 8 DPDK版本&#xff1a;stable-20.11.10 下载源码后&#xff0c;使用meson和ninja编译完成、配置并挂载大页、内核和VFIO设置完成&#xff0c;在dpdk源码目录下的build/…

小程序 UI 风格,引人入胜

小程序 UI 风格&#xff0c;引人入胜

OceanBase 4.X-2F1A 仲裁高可用方案初探

作者&#xff1a;郑增权&#xff0c;爱可生 DBA 团队成员&#xff0c;OceanBase 和 MySQL 数据库技术爱好者。 爱可生开源社区出品&#xff0c;原创内容未经授权不得随意使用&#xff0c;转载请联系小编并注明来源。 本文约 1500 字&#xff0c;预计阅读需要 5 分钟。 背景 对…

10个国内免费AI绘画网站汇总【2024最新】

迎战MidJourney和Stable Diffusion&#xff1a;10款国产AI绘画神器&#xff0c;让你轻松创作出超凡艺术品&#xff01;不论你是初学者还是资深艺术家&#xff0c;这些AI绘画平台都能帮你轻松入门。快来探索这些AI绘画网站&#xff0c;释放你的创意潜能&#xff01; 1、AI绘画创…

Linux系统之nice命令的基本使用

Linux系统之nice命令的基本使用 一、nice命令介绍1.1 nice命令简介1.2 进程优先级介绍 二、nice命令基本语法2.1 nice命令的help帮助信息2.2 nice命令选项解释 三、nice命令的基本使用3.1 查看进程优先级3.2 使用nice启动进程3.3 提高优先级 四、注意事项 一、nice命令介绍 1.…

YCSB基准测试

1、Redis: 下载成功后&#xff0c;加载数据&#xff0c;运行 启动redis: /usr/local/redis/bin/redis-server ./bin/ycsb load redis -P workloads/workloade -p redis.hostlocalhost -p redis.port6379 -p recordcount10000 -p operationcount10000 -threads 32 ./bin/y…

Vue3-尚硅谷笔记

1. Vue3简介 2020年9月18日&#xff0c;Vue.js发布版3.0版本&#xff0c;代号&#xff1a;One Piece&#xff08;n 经历了&#xff1a;4800次提交、40个RFC、600次PR、300贡献者 官方发版地址&#xff1a;Release v3.0.0 One Piece vuejs/core 截止2023年10月&#xff0c;最…

简述RocketMQ从了解到使用

概念篇 背景: 随着队列和虚拟主题使用的增加,ActiveMQ IO模块达到了一个瓶颈。我们尽力通过节流、断路器或降级来解决这个问题,但效果并不理想。于是我们尝试了流行的消息传递解决方案Kafka。不幸的是,Kafka不能满足我们的要求,其尤其表现在低延迟和高可靠性方面,详见下…

后端之路第三站(Mybatis)——入门配置

一、Mybatis是啥&#xff1f; 就是一个用java来操控数据库的框架语言 之前学的datagrip或者navicat这些软件里我们操作数据库&#xff0c;原理是我们编写完的操作语句发送到服务器传送到数据库系统&#xff0c;然后数据库执行完之后再发送给服务器返回给datagrip或者navicat显…

服务器数据恢复—用raid6阵列磁盘组建raid5阵列如何恢复原raid数据?

服务器存储数据恢复环境&#xff1a; 华为OceanStor 5800存储&#xff0c;该存储中有一组由10块硬盘组建的raid6磁盘阵列&#xff0c;供企业内部使用&#xff0c;服务器安装linux操作系统EXT3文件系统&#xff0c;划分2个lun。 服务器存储故障&#xff1a; 管理员发现存储中rai…

多家国产大模型提供OpenAI API服务替代方案,谷歌将推出明星网红AI聊天机器人

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 更多资源欢迎关注 1、OpenAI终止对中国提供服务 6月25日凌晨&#xff0c;多个用户收到OpenAI的推送邮件&#xff0c;信中称&#xff0c;自今年7月9日起&#xff0c;将开始阻止来自非支持国家和地区的API&#xff08;应…