首页 技术 正文
技术 2022年11月8日
0 收藏 402 点赞 1,237 浏览 779 个字

from multiprocessing import Process, Queue

def f1(q);

  for  i   in range(10):

    q.put(i)

def f2(q):

  whlie 1:

   print(q.get())

if   __name__ == ‘__main__’:

  q = Queue(10)#队列的容量

  a = Process(target=f1,args=(q,)

  b = Process(target=f2,args=(q,)

  a.start()

  b.start()

上面的是错误的  因为q.put拿不到值的时候会一直等待 导致程序阻塞 卡在q.put这里

第二种完美解决这个问题  JoinableQueue

from multiprocessing import JoinableQueue

def up(p):

  for i in range(10):

    p.put(i)

  p.join()#等待task_done()返回的信号量和put进去的数量一直才会往下执行

  print(当task_done()返回的信号数量一致时就会执行这里)

def down(p);

  while 1:

    p.get()

    p.task_done()

if  __name__ == “__main__”:

   p = JoinableQueue(30)#这个是队列的容量

   p1 = Process(targer=up,args=(p,))

   p2 = Process(target=down,args=(p,))

   p1.start()

   p2.daemon = True# 将p2设置成守护进程 因为p2一直是死循环,设置成守护进程之后当主程序代码运行完毕,p2就会结束,不会成为僵尸进程

   p2.start()

   p1.join()

   print(子进程运行完毕,开始运行主进程)

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,954
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,479
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,291
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,108
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,740
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,774