Python之父差点砍掉import!认为模块系统是最大败笔?!

前言

大家好,我是倔强青铜三 。欢迎关注我,微信公众号:倔强青铜三。欢迎点赞、收藏、关注,一键三连!!!


"如果当年我把import扔进垃圾桶,今天就不会有pip、也不会有PyPI。"

2003 年 PyCon 的闭门圆桌,Guido 的这句话让全场瞬间安静。
Python 1.x模块系统 被无数人视作开天辟地的创举,可在创建者眼里,它曾是一场险些失控的灾难------嵌套包、相对导入、循环引用的噩梦,早在 1994 年就埋下了祸根。


败笔的种子:1991 年的简单设想如何走向失控

1991 年的 import foo 只有两行核心代码:

  1. foo.py 读进来。
  2. 把名字 foo 绑进当前命名空间。

看似优雅,却留下了三个无法回头的漏洞

  • 无命名空间隔离 :所有模块平铺在同一张表里,foo.barbar.foo 互踩名字。
  • 无版本信息foo.py 升级后,旧脚本静默崩溃,连报错都来不及。
  • 搜索路径黑箱PYTHONPATH 的优先级写死在 C 代码里,用户只能"猜"模块从哪来。

到 Python 1.2 发布时,标准库已有 78 个 .py 文件,平铺命名空间的冲突率首次突破 30%

Guido 在邮件列表写下:

"也许我们根本不该把模块暴露成全局单例。"


差点被砍:1994 年的重构之战

1994 年 5 月,社区爆发"包大爆炸 "事件。

第三方开发者把 soundimagecrypto 全部放入顶级名字,官方库一夜之间被挤到第二页

Guido 提交了史上最具争议的 PEP------"PEP 0:废除 import"

核心提案只有一句:

"用显式加载器 load('path/to/module.py') 取代魔法导入。"

反对者在两周内回邮 400+ 封,核心论点直击要害:

  • 失去"一次编写,到处运行"的易用性。
  • 破坏向后兼容,等于让 Python 1.x 全体用户重写代码。
    最终投票结果:反对 73%,支持 27%
    import 被保留,但留下了妥协补丁
  • 1995 年的 Python 1.4 引入包目录 __init__.py,首次允许嵌套命名空间。
  • 搜索路径改为可配置的 site-packages,把第三方与标准库隔离。

循环炼狱:相对导入的历史幽灵

包目录解决了命名冲突,却带来了新的地狱 ------相对导入

1996 年的 Python 1.5 允许 from .foo import bar,初衷是"让子包自给自足"。

然而早期实现把相对路径写进了编译期常量

c 复制代码
/* import.c */
static char *relative_base = NULL; /* 线程不安全 */

多线程下,两个包同时触发相对导入,relative_base 会被覆盖成野指针,解释器直接段错误。

直到 2000 年的 Python 2.0 才用绝对导入 修复,却把语法级歧义留了下来:

python 复制代码
from foo import bar   # 是顶级 foo,还是当前包的 foo?

为了向后兼容,Python 2 默认优先相对导入 ,导致整整十年里,"绝对导入"必须写成 __future__ 魔法:

python 复制代码
from __future__ import absolute_import

隐藏彩蛋:import 钩子如何让 PyPI 成为可能

模块系统的"败笔"反而催生了生态奇迹

1998 年,Distutils 的作者 Greg Ward 利用import 钩子 (PEP 302 前身)把 .egg 文件塞进 sys.meta_path,首次实现"复制即安装 "。

2005 年 setuptools 把钩子升级为 easy_install,2008 年 pip 沿用同一机制,最终让 PyPI 成为全球最大的开源仓库。

如果没有 1.x 时代留下的"过度灵活",Python 不可能在 2010 年前就拥有 10 万+ 第三方包。


尾声:今天的 import,仍在偿还 1.x 的技术债

2020 年,Python 3.9 引入"命名空间包 ",彻底废除 __init__.py,看似最终解决了目录层级问题。

但核心开发者 Brett Cannon 在博客中坦言:

"我们每修复一次 import,就多背一条 1.x 的兼容包袱。"

从 1991 年的两行代码到 2024 年的 2000 行 C 实现,Python 的模块系统像一棵老树:根是败笔,枝桠却撑起了整片森林

下次你在 PyPI 一键 pip install 时,不妨想想------

如果当年 Guido 真把 import 扔进垃圾桶,今天的 Python 还会是你认识的模样吗?

最后感谢阅读!欢迎关注我,微信公众号:倔强青铜三。欢迎点赞、收藏、关注,一键三连!!!

相关推荐
XINVRY-FPGA8 分钟前
XCVP1802-2MSILSVC4072 AMD Xilinx Versal Premium Adaptive SoC FPGA
人工智能·嵌入式硬件·fpga开发·数据挖掘·云计算·硬件工程·fpga
Q_Q51100828523 分钟前
python+django/flask的情绪宣泄系统
spring boot·python·pycharm·django·flask·node.js·php
撸码猿29 分钟前
《Python AI入门》第9章 让机器读懂文字——NLP基础与情感分析实战
人工智能·python·自然语言处理
二川bro33 分钟前
多模态AI开发:Python实现跨模态学习
人工智能·python·学习
张彦峰ZYF35 分钟前
AI赋能原则1解读思考:超级能动性-AI巨变时代重建个人掌控力的关键能力
人工智能·ai·aigc·ai-native
2301_764441331 小时前
Python构建输入法应用
开发语言·python·算法
love530love1 小时前
【笔记】ComfUI RIFEInterpolation 节点缺失问题(cupy CUDA 安装)解决方案
人工智能·windows·笔记·python·插件·comfyui
Lucky小小吴1 小时前
Google《Prompt Engineering》2025白皮书——最佳实践十四式
人工智能·prompt
AI科技星1 小时前
为什么变化的电磁场才产生引力场?—— 统一场论揭示的时空动力学本质
数据结构·人工智能·经验分享·算法·计算机视觉
青瓷程序设计1 小时前
昆虫识别系统【最新版】Python+TensorFlow+Vue3+Django+人工智能+深度学习+卷积神经网络算法
人工智能·python·深度学习