玩蛇网提供最新Python编程技术信息以及Python资源下载!

请问Python multiprocessing使用困惑求解

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

首先你需要理解的一点是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()

玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd19319.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2017年05月23日 - 11时04分43秒 发布自玩蛇网

您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules