python深入之Python编程执行机制

最近开始系统的学习python。学习机器学习算法的时候用的是python,所以有一定的基础,现在对python进行更深入的学习和理解,并对一些重点知识进行梳理。

每一次学习一种新的编程语言,我都会去搞懂使用该种语言时,其程序到底是按怎样的步骤执行的。上图:

流程图解释:

上图是python程序的执行机制结构图。

1.执行a.py 文件,首先检查在a.py文件中是否存在import命令,即是否引用了其他文件,如果没有,则对a.py文件的代码进行编译,生成中间字节码PyCodeObject,以a.pyc格式文件存储,字节码的作用是持久化a.py文件,即下次再使用该a.py时可以直接调用a.pyc,省去了编译的步骤,加快效率;然后根据a生成的字节码进行解释执行。(所以说python不是单纯的编译语言或者执行语言,是两者的混合语言)

2.1中如果检到引用了其他文件如b.py,则再检查被引用的文件是否被编译过了,且生成了中间字节码存储文件b.pyc。如果存在,还需检查b.pyc的修改时间是否等于源文件最近的修改时间(这里存在pyc文件过期的问题,如果pyc文件过期,即与源文件内容不一致,则该pyc文件失效,需要重新编译源文件产生新的pyc文件),如果是的,则直接调用b.pyc文件而不去执行编译b.py文件,再根据b生成的字节码进行解释执行。

3.2中如果检查不存在b的pyc文件或者b.pyc文件修改时间与源文件最近修改时间不对应,则需要重新对b.py文件进行编译,产生中间字节码,存储与b.pyc中,再根据字节码进行解释执行。

其实.py和.pyc都可以交给解释器直接处理,得到的结果是一样的,但是对它们处理的步骤不一样而已。

猜你喜欢

转载自blog.csdn.net/zx870121209/article/details/80918052