请问Python multiprocessing使用困惑求解,,自己在做一个python
请问Python multiprocessing使用困惑求解,,自己在做一个python
自己在做一个python的小程序时要用到python multiprocessing.dummy,搜到一些资料用map啥的,但还是有一些困惑。
我把问题抽象下就是:我要找100内一个特定的数(比如89,额,不要吐槽得用二分啥的,这里我只是抽象下),我开4个线程,每个线程循环25个数查找(1-25,26-50...),在第四个线程判断时找到89,线程退出,同时其他三个线程也立即终止。请问以上的操作我该怎么编写出python,希望能给出简单源码学习,不甚感激啊!
首先你需要理解的一点是CPython的Multiprocessing模块实现的并不是多线程,而是多进程。这主要是因为操作系统对于解释器的限制。
你说的这个需求有多种方式可以实现,下面的代码是使用信号量的方式:
import multiprocessingdef 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() returnif __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()
编橙之家文章,
相关内容
- Redis存储带时间戳分类实时数据问题求教,redis实时数据
- Python类似java jstack命令的功能是什么,pythonjstack,最近有
- Python源码分析快排统计次数时if是否要算入计数中,p
- Python用requests和BeautifulSoup抓取信息失败请大神指导,
- Python gevent与bottle有哪些要避免的坑,pythongevent,目前发
- Python stmplib库邮件发送情况反馈怎么实现,pythonstmplib
- Flask判断是当前页面的简单写法是什么,flask当前页,现
- python支持两个应用程序同时启动吗?,python应用程序,i
- Python 身份验证使用装饰器是最高效的吗,python身份验证
- Supervisor捕获不到python输出内容是为什么,supervisorpyth
评论关闭