免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3344 | 回复: 4
打印 上一主题 下一主题

multiprocessing.Pipe只有开始运行是对的,后面就乱了 [复制链接]

论坛徽章:
1
操作系统版块每日发帖之星
日期:2016-06-12 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2018-01-02 10:09 |只看该作者 |倒序浏览
  1. #coding:utf-8

  2. import multiprocessing
  3. import time
  4. from multiprocessing import Process,freeze_support


  5. def proc1(pipe):
  6.     i=0
  7.     while True:
  8.         i=i+1
  9.         print "\nPROC1-SEND %s"%i
  10.         pipe.send(i)
  11.         
  12.         time.sleep(3)
  13.         print '\nPROC1-RECV:',pipe.recv()
  14. def proc2(pipe):
  15.     while True:
  16.         print '\n\t\t\tproc2 recv:',pipe.recv()
  17.         time.sleep(3)
  18.         print "\n\t\t\tproc2 send %c"% 65
  19.         pipe.send('A')


  20. # Build a pipe
  21. pipe = multiprocessing.Pipe(duplex=True)
  22. #print pipe

  23. # Pass an end of the pipe to process 1
  24. p1   = multiprocessing.Process(target=proc1, args=(pipe[0],))
  25. # Pass the other end of the pipe to process 2
  26. p2   = multiprocessing.Process(target=proc2, args=(pipe[1],))

  27. if __name__ == '__main__':
  28.         freeze_support()
  29.         p1.start()
  30.         p2.start()
  31.         p1.join()
  32.         p2.join()
复制代码
输出结果
PROC1-SEND 1

                        proc2 recv: 1

PROC1-RECV:
                        proc2 send A

                        proc2 recv:A

PROC1-SEND 2
2

PROC1-RECV:
                        proc2 send A

论坛徽章:
1
15-16赛季CBA联赛之新疆
日期:2017-03-09 12:33:45
2 [报告]
发表于 2018-01-03 12:52 |只看该作者
回复 1# yakczh_cu

我测试你的代码,在python2上是完全正确,
在python3上,只要修改了print的代码,也是完全正确。所以不知道你是如何不正确的。

  1. PROC1-SEND 1

  2.                         proc2 recv: 1

  3.                         proc2 send A

  4. PROC1-RECV: A

  5. PROC1-SEND 2

  6.                         proc2 recv: 2

  7.                         proc2 send A

  8. PROC1-RECV: A

  9. PROC1-SEND 3

  10.                         proc2 recv: 3

  11.                         proc2 send A

  12. PROC1-RECV: A

  13. PROC1-SEND 4

  14.                         proc2 recv: 4

  15.                         proc2 send A

  16. PROC1-RECV: A

  17. PROC1-SEND 5

  18.                         proc2 recv: 5

  19.                         proc2 send A

  20. PROC1-RECV: A

  21. PROC1-SEND 6

  22.                         proc2 recv: 6

  23.                         proc2 send A

  24. PROC1-RECV: A

  25. PROC1-SEND 7

  26.                         proc2 recv: 7

  27.                         proc2 send A

  28. PROC1-RECV: A

  29. PROC1-SEND 8

  30.                         proc2 recv: 8
复制代码

论坛徽章:
1
操作系统版块每日发帖之星
日期:2016-06-12 06:20:00
3 [报告]
发表于 2018-01-03 13:39 |只看该作者
回复 2# jeppeter

windows下试一下

论坛徽章:
1
15-16赛季CBA联赛之新疆
日期:2017-03-09 12:33:45
4 [报告]
发表于 2018-01-04 08:43 |只看该作者
回复 3# yakczh_cu

我测试了一下,还是对的。我用的系统是anaconda的python3.5 系统,在window7 x64系统下面。

论坛徽章:
1
操作系统版块每日发帖之星
日期:2016-06-12 06:20:00
5 [报告]
发表于 2018-01-04 14:14 |只看该作者
回复 4# jeppeter
2.7呢, 这个是主流的版本

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP