python中threading模块关于多线程一个简单的例子

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()

结果如下图
python中threading模块关于多线程一个简单的例子_第1张图片

如果不用多线程的话,两个方法总共执行时间会是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())
然后结果不对找半天。万恶的自动填充,以后可千万注意参数的使用啊!

你可能感兴趣的:(Python)