电话
400 9058 355
sys.modules 是 Python 的模块缓存字典,键为模块名、值为已加载模块对象;命中则跳过导入全流程,支持强制重载与 mock 注入,但需谨慎处理引用和状态一致性。
Python 导入模块时不会每次都重新执行源码,而是先查 sys.modules —— 它是一个字典,键是模块名(如 'os'、'my_package.submod'),值是已加载的模块对象。命中缓存就直接返回,跳过查找、编译、执行全过程。
这意味着:同一模块在同一个解释器生命周期内,import 多次也只初始化一次;手动修改 sys.modules 会影响后续导入行为,但需谨慎。
开发中改了模块代码又不想重启解释器?可以删掉对应条目再 import,触发重新加载。但这不是“热重载”,只是绕过缓存重新走一遍导入流程。
del sys.modules['mymodule'] 后再 import mymodule,会重新执行模块顶层代码
a.py 里 import mymodule),删除后不会自动更新那些已持有的引用,旧对象仍存在有些框架(如 pytest、某些插件系统)会临时往 sys.modules 写入伪造模块,用于 mock 或隔离测试环境。
sys.modules['requests'] = MockRequests() 可让后续 import requests 拿到 mock 对象sys.modules 管缓存,sys.path 才管“去哪找”。即使把模块名加进 sys.modules,如果没真正加载过,它的 __file__ 可能为 None,且没有实际属性和功能。
常见误判场景:
'mymod' in sys.modules 判断“模块是否存在”不准确——它只说明是否曾成功导入过,不代表当前可用types.ModuleType('mymod') 进 sys.modules,再 import mymod 会失败(因为导入机制发现已有缓存,但该对象不满足模块协议)__name__、__dict__ 等关键属性,否则运行时报错模块缓存看似简单,但涉及导入协议、对象生命周期和引用关系,动它之前得清楚谁持有该模块的引用、哪些状态没被清理。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...