码迷,mamicode.com
首页 > 编程语言 > 详细

PYTHON多线程

时间:2017-07-23 10:02:59      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:允许   result   个人   print   thread   start   python   提高   []   

  在单线程的情况下,程序是逐条指令顺序执行的。同一时间只做一个任务,完成了一个任务再进行下一个任务。比如有5个人吃饭,单线程一次只允许一个人吃,一个人吃完了另一个人才能接着吃,假如每个人吃饭都需要1分钟,5个人就需要5分钟。多线程的情况下,程序就会同时进行多个任务,虽然在同一时刻也只能执行某个任务的一条指令,但是由于CPU运行非常快。可以在极短的时间内切换到另一个任务。从宏观效果来看,CPU是多个任务同时执行的。也拿刚才的吃饭做比喻,多线程就相当于5个人同时吃饭,5个人吃完花费的时间和一个人相同,也是1分钟。效率的提高是不言而喻的。下面我们用程序来实现一下,首先是单线程。

import time
def begin(n):
    print("第%s个人开始吃饭"%(n+1))
    time.sleep(1)
    print("第%s个人吃完饭了" %(n+1))
begin_time = time.time()#开始吃饭时间
for count in range(5):
    begin(count)
print("5个人吃饭花费的总时间为",time.time()-begin_time)#统计吃饭用时

运行结果如下:

第1个人开始吃饭

第1个人吃完饭了

第2个人开始吃饭

第2个人吃完饭了

第3个人开始吃饭

第3个人吃完饭了

第4个人开始吃饭

第4个人吃完饭了

第5个人开始吃饭

第5个人吃完饭了

5个人吃饭花费的总时间为 5.002005100250244

从运行结果可以清晰看出,总共用了5秒时间。

             

下面我们再试试多线程:

import threading
import time
def begin(n):
    print("第%s个人开始吃饭"%n)
    time.sleep(1)
    print("第%s个人吃完饭了" %n)
begin_time = time.time()
t_result = []
for count in range(5):
    t = threading.Thread(target=begin, args=("%s"%(count+1),))
    t.start()
    t_result.append(t)
for t in t_result:
    t.join()
print("5个人吃饭花费的总时间为",time.time()-begin_time)

程序运行结果如下:

 第1个人开始吃饭

第2个人开始吃饭

第3个人开始吃饭

第4个人开始吃饭

第5个人开始吃饭

第2个人吃完饭了

第1个人吃完饭了

第5个人吃完饭了

第4个人吃完饭了

第3个人吃完饭了

5个人吃饭花费的总时间为 1.0021629333496094

从运行结果可以清晰看出,总共用了1秒时间。

PYTHON多线程

标签:允许   result   个人   print   thread   start   python   提高   []   

原文地址:http://www.cnblogs.com/chengyonggao/p/7223501.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!