时间:2021-05-22
本文研究的主要是Python之reload流程的相关内容,具体如下。
在Python中,reload() 用于重新载入之前载入的模块。
reload() 函数语法:
reload(module)Python中 import 只执行一次,后续的 import 仅仅在 sys.modules 中查找是否存在对应的模块对象,而对于源文件进行修改后想要立即重新导入该文件而不想整体重新执行程序时, reload 就在该处派上用途了。在实际中,测试代码修改结果,或者对于不能停止的服务需要动态改变运行行为 reload 是非常有用的。
reload 的执行流程如下所示:
1)在 sys.modules 中查找到对应模块名的模块对象;
2)针对该模块名的 执行文件 属性,找到对应文件并重新编译该文件执行;
3)将代码执行中产生的对象依次更新到原模块对象的属性中;
从上面执行流程中我们可以看到如下几点:
1)模块对象是可变的,在 reload 执行过程中只是修改了该模块对象,因此在 reload 后原来的引用还是指向该模块对象;
2)reload 过程中,文件中代码重新执行,创建新的对象并绑定到模块的属性中;
3)reload 模块中的 import 和 reload 流程与该模块是否 reload 无关,一个模块 reload 并不会导致其中的 import 递归重新载入;
4)对于 from * import * 来说其相当于是在本地创建了同名的变量指向模块中的同名属性所引用对象, reload 会创建新对象(部分不可变对象除外),其仍然指向旧变量,一般情况下需要重新赋值;
基于此,测试如下代码:
#----- 被导入代码 reloadImported.py ------ print(' excute code in imported file') x = [] y = 1 #----- 测试代码 test.py -------- sep = ': ' print('---- import module ----') import reloadImported from reloadImported import x print(' id(reloadImported)', id(reloadImported), sep=sep) print(' id(reloadImported.x)', id(reloadImported.x), sep=sep) print(' id(reloadImported.y)', id(reloadImported.y), sep=sep) print(' id(x)', id(x), sep=sep) print('---- reload module ----') from importlib import reload reload(reloadImported) print(' id(reloadImported)', id(reloadImported), sep=sep) print(' id(reloadImported.x)', id(reloadImported.x), sep=sep) print(' id(reloadImported.y)', id(reloadImported.y), sep=sep) print(' id(x)', id(x), sep=sep) from reloadImported import x print(' new x id(x)', id(x), sep=sep)执行结果如下所示:
---- import module ---- excute code in imported file id(reloadImported): 30322880 id(reloadImported.x): 29841208 id(reloadImported.y): 1502597584 id(x): 29841208 ---- reload module ---- excute code in imported file id(reloadImported): 30322880 id(reloadImported.x): 29842088 id(reloadImported.y): 1502597584 id(x): 29841208 new x id(x): 29842088总结
以上就是本文关于Python之reload流程实例代码解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python爬虫DNS解析缓存方法。分享给大家供大家参考,具体如下:前言:这是Python爬虫中DNS解析缓存模块中的核心代码,是去年的代码了,现
本文实例讲述了python命令行参数解析OptionParser类的用法,分享给大家供大家参考。具体代码如下:fromoptparseimportOptionP
本文实例讲述了Python解析xml中dom元素的方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下:fromxml.domimportminido
jQuery实现的多选框联动插件复制代码代码如下://使用:$(_event_src_).autoSelect(_reload_,reload_url);//前
这篇文章主要介绍了Python解析json代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下什么是j