当前位置:   article > 正文

Python Pool类多进程 apply_async 异步变成了阻塞解决方法_python apply_sync调用异步函数进不去

python apply_sync调用异步函数进不去

出错代码:

  1. if __name__ == '__main__':
  2. ip_arr=get_ip_list()
  3. pool=Pool(processes=4)
  4. for temp in ip_arr:
  5. res = pool.apply_async(check_ip,(temp,)).get()
  6. if res :
  7. ip_list.append(res )
  8. pool.close()
  9. pool.join()
  10. print(arr)

这段代码运行会发现是阻塞运行的

原因是apply_async后面 get()等待线程运行结束才会下一个

而apply_async刚好又是异步以主程序为主的,所以这段代码实际变成了阻塞

改成:

  1. if __name__ == '__main__':
  2. ip_arr=get_ip_list()
  3. pool=Pool(processes=4)
  4. for temp in ip_arr:
  5. arr.append(pool.apply_async(check_ip,(temp,)))
  6. pool.close()
  7. pool.join()
  8. ip_list=[]
  9. for temp in arr:
  10. if temp.get():
  11. ip_list.append(temp.get())
  12. print(ip_list,len(ip_list))

当然有更好的方法来获取他的返回值,只是这个方法比较方便~

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/151534
推荐阅读
相关标签
  

闽ICP备14008679号