python多线程不推荐使用thread模块,thread模块的功能threading模块都用,而且后者更简单安全好用。下面写一个最简单的多线程的例子,主要记录一下犯的很低级的错误,以后不能再犯了。直接贴代码,一看就懂:
# coding=utf-8
# threading模块中Thread类的一个测试程序
import threading
from time import sleep, ctime
def function0():
print "start function0 at: ", ctime()
sleep(5)
print "stop function0 at: ", ctime()
def function1():
print "start function1 at: ", ctime()
sleep(3)
print "stop function1 at: ", ctime()
def main():
print "starting at: ", ctime()
t0 = threading.Thread(target=function0)
t1 = threading.Thread(target=function1)
t0.start()
t1.start()
t0.join()
t1.join()
print "all done at: ", ctime()
if __name__=='__main__':
main()
如果不用多线程的话,两个方法总共执行时间会是8秒,而且是function0先开始再结束,然后function1开始再结束。用了多线程之后,总共用了5秒,而且function0 function1几乎同时开始执行。
注意: 就这么简单的一个例子我都犯了一个错误,
t0 = threading.Thread(target=function0)
t1 = threading.Thread(target=function1)
这两行代码之前被我写成了
t0 = threading.Thread(target=function0())
t1 = threading.Thread(target=function1())
然后结果不对找半天。万恶的自动填充,以后可千万注意参数的使用啊!