下面代码摘自web.py框架
selfimport sys
import os
class Reloader:
if sys.platform.startswith('java'):
SUFFIX = '$py.class'
else:
SUFFIX = '.pyc'
def __init__(self):
self.mtimes = {}
def __call__(self):
import pdb
pdb.set_trace()
for mod in sys.modules.values():
self.check(mod)
def check(self, mod):
if not (mod and hasattr(mod, '__file__') and mod.__file__):
return
try:
mtime = os.stat(mod.__file__).st_mtime
except (OSError, IOError):
return
if mod.__file__.endswith(self.__class__.SUFFIX) and os.path.exist(mod.__file__[:-1]):
mtime = max(os.stat(mod.__file__[:-1].st_mtime), mtime)
if mod not in self.mtimes:
self.mtimes[mod] = mtime
elif self.mtimes[mod] < mtime:
try:
reload(mod)
self.mtimes[mod] = mtime
except ImportError:
pass
reloader = Reloader()
reloader()
第一个知识点:
self.__class__.SUFFIX,首先python一切皆对象,类实际上在python的世界里面也是一个对象,__class__至少在下面这种情况中是有用的:当一个类中的某个成员变量是所有该类的对象的公共变量时.
很像java中的static变量。
第二个知识点:
__import__与reload的区别:
(1):多次重复使用import语句时,不会重新加载被指定的模块,只是把对该模块的内存地址给引用到本地变量环境。
(2)对已经加载的模块进行重新加载,一般用于原模块有变化等特殊情况,reload前该模块必须已经import过。reload会重新加载已加载的模块,但原来已经使用的实例还是会使用旧的模块,而新生产的实例会使用新的模块;reload后还是用原来的内存地址;不能支持from。。import。。格式的模块进行重新加载。
(3)通常在动态加载时可以使用到这个函数,比如你希望加载某个文件夹下的所用模块,但是其下的模块名称又会经常变化时,就可以使用这个函数动态加载所有模块了,最常见的场景就是插件功能的支持。比如__import__可以这样__import__('os',globals(),locals(),['path','pip']) ,reload就不行了。
具体可以参考看看这篇文章http://www.cnblogs.com/MaggieXiang/archive/2013/06/05/3118156.html
第三个知识点:
__call__的用法,可调用对象,这个确实是第一次接触到,大概的用法就是我们只需要去重载这个方法,那么我们就可以像调用方法的形式去调用对象,那么它就会去回调这个__call__方法,具体的好处可以参看这个博客