栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

扭曲:为什么将延迟的回调传递给延迟的线程会导致该线程突然阻塞?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

扭曲:为什么将延迟的回调传递给延迟的线程会导致该线程突然阻塞?

好吧,正如扭曲的文档所说:

延迟不会使代码神奇地无法阻止

每当使用阻塞代码(例如)时

sleep
,都必须将其推迟到新线程。

#!/usr/bin/env pythonfrom twisted.internet import reactor,defer, threadsfrom twisted.internet.task import LoopingCallimport timedef main_loop():    print 'doing stuff in main loop.. do not block me!'def aBlockingRedisCall(x):    if x<5: #all connections are busy, try later        print '%s is less than 5, get a redis client later' % x        x+=1        d = defer.Deferred()        d.addCallback(aBlockingRedisCall)        reactor.callLater(1.0,d.callback,x)        return d    else:         print 'got a redis client; doing lookup.. this may take a while'        def getstuff( x ): time.sleep(3) return "stuff is %s" % x        # getstuff is blocking, so you need to push it to a new thread        d = threads.deferToThread(getstuff, x)        d.addCallback(gotFinalResult)        return ddef gotFinalResult(x):    return 'final result is %s' % xdef result(res):    print resdef aBlockingMethod():    print 'going to sleep...'    time.sleep(10)    print 'woke up'def main():    lc = LoopingCall(main_loop)    lc.start(2)    d = defer.Deferred()    d.addCallback(aBlockingRedisCall)    d.addCallback(result)    reactor.callInThread(d.callback, 1)    reactor.run()if __name__=='__main__':    main()

如果redis api不太复杂,则可以使用twisted.web重写它,而不是仅在很多线程中调用阻塞的api,这样会更自然。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/394527.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号