python multiprocessing使用问题
迷茫
迷茫 2017-04-17 13:38:28
[Python讨论组]

自己在做一个python的小程序时要用到python multiprocessing.dummy,搜到一些资料用map啥的,但还是有一些困惑。
我把问题抽象下就是:我要找100内一个特定的数(比如89,额,不要吐槽得用二分啥的,这里我只是抽象下),我开4个线程,每个线程循环25个数查找(1-25,26-50...),在第四个线程判断时找到89,线程退出,同时其他三个线程也立即终止。请问以上的操作我该怎么编写出python,希望能给出简单源码学习,不甚感激啊!

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(1)
PHP中文网

首先你需要理解的一点是CPython的Multiprocessing模块实现的并不是多线程,而是多进程。这主要是因为操作系统对于解释器的限制。
你说的这个需求有多种方式可以实现,下面的代码是使用信号量的方式:

import multiprocessing

def f (start, end, target, fin):
    for i in range(start, end+1):
        if fin.is_set():
            print 'Other process found target, exit'
            return
        if i == target:
            print 'Target: ' + str(target) + ' Found'
            fin.set()
            return


if __name__ == "__main__":
    fin = multiprocessing.Event()
    size = 24
    target = 89
    for start in (1, 26, 51, 76):
        multiprocessing.Process(target = f, args = (start, start+size, target, fin)).start()
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号