[求助] Python 多线程通信 (好心人救救孩子,点开工资超级加倍)

2020-05-01 00:29:00 +08:00
 echome

如何从一个需要执行很久的线程当中获取返回数据

有一个线程当中的函数做 funcA,funcA 需要花费很多时间,并且 funcA 会返回我们需要的数据 我该如何获得其中的数据? 网上一般是

  1. 使用 queue 作为全局变量,但是如果在 funcA 里面 put 数据的话,在主线程当中 get 数据会返回 None,因为 funcA 会花费很多的时间,所以主线程获得的都是 None 。
q = queue.Queue(10)
def funcA():
     
     # 花费很多时间做一些事得到一个数组叫做 res
    for i in res:
        q.put(i)

res=[]
while not empty(q.get()):
   res.append(q.get())
  1. 是重构 thread 模块写一个自己的 thread 类,其中新建一个 get_result 方法。如果重构的话会发现也是 None,因为在 funcA 会使用很多的时间,然后使用 get_result 方法的话会返回 None,因为在 run 方法当中并没有返回数据。
class MyThread(Thread):
    def __init__(self, target, args):
        super(MyThread, self).__init__()
        self.func = target
        self.args = args


    def run(self):
        print("I have done")
        self.result = self.func(*self.args)

    def get_result(self):
        while self.lock:
            pass
        return self.result

.............
.............
thread = MyThread(target=funca, args=(domain,))
thread.start()
res=thread.get_result()

我也想过方法,比如在 get_result 当中等待 run 方法执行完毕,但是这样就会导致线程阻塞的问题

所以问题是如何在需要花费很多时间的线程当中得到数据并且不会阻塞。 跪求大神!!!

4270 次点击
所在节点    Python
22 条回复
Marinej
2020-05-07 15:36:54 +08:00
@Marinej 妈个鸡没看完, 用 asyncio, 里面也可以用线程池,但是可以用异步的写法
ps1aniuge
2020-05-08 16:08:18 +08:00
看得我脑仁疼,一个头 2 个大。

楼主是 cpu 密集型,还是 io 密集型啊?
cpu 密集就用多进程,任你开 2 万个线程(池),也解决不了你的问题。因为多线程,只能用单核,对吧?
io 密集就用 asyncio 啊。为啥么要折腾线程池?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/667793

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX