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

结果如下图
在这里插入图片描述

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值