在Python大型项目中,其实是可以出现循环引用的,例如:间接递归时,两个函数分别存放在不同的模块(Python文件)中,而且互相调用。
参考我的代码片中的《循环引用示例代码片》,test1.py(执行入口)和test2.py在执行时是会报错的,原因就在于Python中文件头上的import在执行时,会寻找没有被引入的模块进行引入。在此例子中,test1和test2互相引用,执行入口为test1,解释器先执行test1,发现import了test2,再载入test2,发现又import了test1,再载入test1,发现又import了test2,此时因为test2已被引入,所以解释器就认为pkg_demo包没有test2这个属性而报错。
如果工程中确实需要这种循环引用,那么应该把test1.py文件中开头的import移到do_test1函数内部,放在执行do_test2之前,该例子即可正确执行。因为该import没有放在文件头,所以只有在do_test1函数被执行时才会执行。当解释器执行test1时,调用do_test1函数,其中import了test2,解释器载入test2,发现开头又import了test1,再载入test1,因为test1中的import是在do_test1函数内部的,载入时仅加载函数定义,并不会执行,所以test1载入结束,test2也相应载入结束,继续执行调用do_test2函数,在do_test2函数内部又调用了do_test1,这样就会反复循环调用了,达到设计本意。
当然,我为了尽可能的简洁,该例子最后还是会报错,是因为没设结束条件,到达了递归调用层次的极限了,这个和循环引用无关。
代码片URL:
https://code.csdn.net/snippets/2153539