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

旧线程完成后如何启动新线程?

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

旧线程完成后如何启动新线程?

正如我在评论中建议的那样,我认为使用a

multiprocessing.pool.ThreadPool
是合适的-
因为它可以自动处理许多您在代码中手动执行的线程管理。一旦所有线程都通过
ThreadPool
apply_async()
方法调用排队等待处理,唯一需要做的就是等待它们全部完成执行(当然,除非您的代码可以做其他事情)。

我已经将链接的答案中的代码翻译为另一个相关问题,因此它与您在使当前上下文中的内容易于理解时所执行的操作更加相似。

from multiprocessing.pool import ThreadPoolfrom random import randintimport threadingimport timeMAX_THREADS = 5print_lock = threading.Lock()  # Prevent overlapped printing from threads.def query_data(trade):    trade_id = trade[0][1][:6]    time.sleep(randint(1, 3))  # Simulate variable working time for testing.    with print_lock:        print(trade_id)def process_trades(trade_list):    pool = ThreadPool(processes=MAX_THREADS)    results = []    while(trade_list):        trade = trade_list.pop()        results.append(pool.apply_async(query_data, (trade,)))    pool.close()  # Done adding tasks.    pool.join()  # Wait for all tasks to complete.def test():    trade_list = [[['abc', ('%06d' % id) + 'defghi']] for id in range(1, 101)]    process_trades(trade_list)if __name__ == "__main__":    test()


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

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

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