0

0

Python 面向对象设计的反模式总结

冷炫風刃

冷炫風刃

发布时间:2026-02-16 15:33:30

|

112人浏览过

|

来源于php中文网

原创

__init__只做最小状态赋值,重操作拆为显式方法;优先组合而非滥用继承;方法应无副作用,避免self堆砌临时状态;慎用__getattribute__等魔术方法,以清晰直白为先。

python 面向对象设计的反模式总结

__init__ 当成万能初始化入口,忽略职责边界

很多新手一写类就往 __init__ 里塞大量逻辑:读配置、连数据库、加载文件、校验参数……结果对象构造失败时堆栈深、错误难定位,且无法单独测试初始化各环节。

真正该放进去的只有「对象自身状态的最小必要赋值」。其他重操作应拆成显式方法,比如 connect()load_config(),让调用者按需触发。

  • __init__ 中避免 I/O 操作(如 open()requests.get()
  • 参数校验可保留,但复杂逻辑建议抽到 _validate_params() 并显式调用
  • 若必须延迟初始化,用 @property__getattr__ 做懒加载,别硬塞进 __init__

滥用继承替代组合,导致类爆炸和脆弱基类

看到“XX 是一种 YY”,就立刻写 class XX(YY),结果基类一改,十几个子类全挂;或者为了复用两行代码,硬造一个单方法父类。

Python 的鸭子类型和模块化更适配组合。继承只在「严格满足 is-a 关系 + 需要多态调度」时才成立,比如 FileReaderDatabaseReader 共享统一接口 read(),且上层用 isinstance(obj, Reader) 做类型判断。

立即学习Python免费学习笔记(深入)”;

iHuzu ECWS 狐族企业建站系统1.0 beta3
iHuzu ECWS 狐族企业建站系统1.0 beta3

iHuzuCMS狐族内容管理系统,是国内CMS市场的新秀、也是国内少有的采用微软的ASP.NET 2.0 + SQL2000/2005 技术框架开发的CMS,充分利用ASP.NET架构的优势,突破传统ASP类CMS的局限性,采用更稳定执行速度更高效的面向对象语言C#设计,全新的模板引擎机制, 全新的静态生成方案,这些功能和技术上的革新塑造了一个基础结构稳定功能创新和执行高效的CMS。iHuzu E

下载
  • 优先用实例变量持有依赖对象(如 self.parser = JSONParser()),而非继承
  • 抽象基类(ABC)比普通父类更适合定义契约,避免“空壳父类”污染继承链
  • super().__init__() 在多重继承中容易漏调或重复调,不如显式调用目标类方法

self 当全局变量用,堆砌状态导致行为不可预测

在方法里不断给 self 赋值临时字段:self._temp_resultself._processed_items……最后谁也说不清哪些字段是对象固有状态,哪些只是某次调用的中间产物。

这会让方法难以复用、并发不安全、序列化出错,还掩盖了真正的数据流——本该是函数输入/输出的东西,被藏进了隐式状态里。

  • 方法尽量无副作用:输入参数,返回结果,不修改 self(除非明确是 mutator 方法,如 append()
  • 临时计算结果用局部变量,别存 self;真需要跨方法传递,考虑重构为新类或用 dataclass 封装上下文
  • __dict__ 动态增删属性是危险信号,说明设计没收敛,该用 __slots__ 或类型注解约束了

过度设计 __getattribute____getattr__,破坏可读性与调试路径

为了“看起来优雅”,用 __getattribute__ 拦截所有属性访问,自动路由到嵌套对象、动态生成方法、甚至查字典 fallback……结果 print(obj.x) 报错时根本看不出 x 是不存在、被拦截了、还是抛了异常。

这些魔术方法不是语法糖,是调试地狱入口。95% 的场景,用显式委托(def x(self): return self._inner.x)或 @property 更直白可靠。

  • __getattr__ 只应在「明确知道某些属性缺失时有合理 fallback」时使用(如兼容旧字段名)
  • __getattribute__ 几乎不该碰;真要代理,优先用 __getattr__ + 显式 super().__getattribute__()
  • IDE 和静态检查工具(如 mypy)对魔术方法支持弱,会导致类型提示失效、跳转失效

最难的不是写出能跑的面向对象代码,而是忍住不用那些“看起来很酷”的机制。每次加一个 __ 开头的方法,先问自己:不用它,能不能靠更直白的函数、更清晰的字段、更小的类来解决?

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

12

2026.02.03

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

57

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

60

2025.11.27

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

22

2025.11.27

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

22

2025.11.27

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

22

2025.11.27

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

85

2025.09.18

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号