twisted:调用deferredlist多线程并发执行任务然后收集结果

最近想通过twisted实现多线程并发去执行一件耗时的事,然后等这些线程都执行完毕后收集他们的结果做一些事。查了下twisted的文档发现deferredlist正好就是做这中事的。附上例子。。。耗时的事用time.sleep来代替了

 

#! /usr/bin/env python
# -*- coding: utf-8 -*-
#Author:pako
#Email/gtalk:zealzpc@gmail.com
from twisted.python import threadable
threadable.init(1)
from twisted.internet import threads, reactor,defer
from random import randint
import time
    
def run():
    
    result=[]
    
    def listCallback(result):  
        """
                    拿到所有线程执行完返回的结果
        """
        result=[r[1] for r in result]
        print result
        print "deferlist result =", result
    
    def doSomeLongTimeThing(sleeptime=0):  
        """ 
                    每个线程同时做的耗时的事
        """  
        print sleeptime
        time.sleep(sleeptime)
        return sleeptime
    
    deferlist=[]
    #创建deferlist中的deferred
    for i in range(10):
        d = threads.deferToThread(doSomeLongTimeThing,sleeptime=randint(3,5))
        deferlist.append(d)
    #创建deferredlist
    dl = defer.DeferredList(deferlist)
    #给deferredlist添加回调函数
    dl.addBoth(listCallback)
    print "1st line after the addition of the callback"  
    print "2nd line after the addition of the callback"  

if __name__ == '__main__':  
    run()
    reactor.run()  
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值