一.管道(多个时数据不安全)   Pipe 类

    (像队列一样,数据只能取走一次)

  conn1,conn2 = Pipe()     建立管道

  .send()   发送

  .recv()   接收

二.事件(等待)     Event类

  名 = Event()   建立一个事件(默认状态为False)  名.set()   改变值为True  名.clear()  改变值为False  名.is_set()  查看事件的状态  名.wait()   如果状态是False 阻塞              True  不阻塞

三.信号量    Semaphore类

   (进程锁时只允许串行,而信号量允许多个)

  内部维护了一个计数器,acquire-1,release+1,

  为0的时候,其他的进程都要在acquire之前等待

  名 = Semaphore(数量)

  名.acquire()

  锁的代码

  名.release()

四.进程池(进程的创建和销毁是很有消耗的,影响代码执行效率)

  名 = Pool(数量)

  1.   名.map(函数,迭代):异步提交任务,并且传参需要可迭代类型的数据,

              自带close和join功能

多进程和进程池的效率比较:

  2.res = apply(f1,args=(i,))  #同步执行任务,必须等任务执行结束

      才能给进程池提交下一个任务,可以直接拿到返回结果res

  3.res_obj = apply_async(f1,args=(i,))  #异步提交任务,

    可以直接拿到结果对象,从结果对象里面拿结果,要用get方法,

    get方法会阻塞程序,没有拿到结果会一直等待

  4.Close : 锁住进程池,防止有其他的新的任务在提交给进程池

      Join : 等待着进程池将自己里面的任务都执行完

五.回调函数(进程池Pool类)

  Apply_async(f1,args=(i,),callback=function)

  #将前面f1这个任务的返回结果作为参数传给callback指定的那个function函数

day 32 管道 事件 信号量 进程池的更多相关文章

  1. python之路--管道, 事件, 信号量, 进程池

    一 . 管道 (了解) from multiprocessing import Process, Pipe def f1(conn): # 管道的recv 里面不用写数字 from_main_proc ...

  2. python之管道, 事件, 信号量, 进程池

    管道:双向通信 2个进程之间相互通信 from multiprocessing import Process, Pipe def f1(conn): from_zjc_msg = conn.recv( ...

  3. Python 并发编程(管道,事件,信号量,进程池)

    管道 Conn1,conn2 = Pipe() Conn1.recv() Conn1.send() 数据接收一次就没有了 from multiprocessing import Process,Pip ...

  4. 并发编程7 管道&事件&信号量&进程池(同步和异步方法)

    1,管道 2.事件 3.信号量 4.进程池的介绍&&进程池的map方法&&进程池和多进程的对比 5.进程池的同步方法和异步方法 6.重新解释同步方法和异步方法 7.回调 ...

  5. python并发编程之进程2(管道,事件,信号量,进程池)

    管道 Conn1,conn2 = Pipe() Conn1.recv() Conn1.send() 数据接收一次就没有了 from multiprocessing import Process,Pip ...

  6. python--管道, 事件, 信号量, 进程池

    一 . 管道 (了解) from multiprocessing import Process, Pipe def f1(conn): # 管道的recv 里面不用写数字 from_main_proc ...

  7. python 管道 事件(Event) 信号量 进程池(map/同步/异步)回调函数

    ####################总结######################## 管道:是进程间通信的第二种方式,但是不推荐使用,因为管道会导致数据不安全的情况出现 事件:当我运行主进程的 ...

  8. day 32 管道,信号量,进程池,线程的创建

    1.管道(了解) Pipe(): 在进程之间建立一条通道,并返回元组(conn1,conn2),其中conn1,conn2表示管道两端的连接对象,强调一点:必须在产生Process对象之前产生管道. ...

  9. GIL与普通互斥锁区别,死锁现象,信号量,event事件,进程池与线程池,协程

    GIL与普通互斥锁区别 GIL锁和互斥锁的异同点 相同: 都是为了解决解释器中多个线程资源竞争的问题 异: 1.互斥锁是Python代码层面的锁,解决Python程序中多线程共享资源的问题(线程数据共 ...

随机推荐

  1. 数控AGC实现(转)

    相关链接:    一种混合式高动态范围AGC算法与FPGA实现     http://www.sohu.com/a/221438387_781333 基于FPGA的快速自动增益控制系统设计      ...

  2. C# struct and enum

    struct Person { public int age; public string name; public string fname; public string class; } enum ...

  3. 框架:Spring IoC

    Spring篇 第二章.Spring IoC简介 一.基本概念 控制反转是一个比较抽象的概念,是Spring框架的核心,用来消减计算机程序的耦合问题. 依赖注入是IoC的另外一种说法,只是从不同的角度 ...

  4. python3 自学第一天,python 介绍

    1.python的介绍: 是一个无聊的人创造的 2.python的格式: 跟java这些语言格式不一样用的是缩进来编码(区块) 一般是四个空格,这样更简洁 3.编码格式: python3跟python ...

  5. lvs的FULLNAT

  6. win7 java环境变量配置

    进行win7下Java环境变量配置      在"系统变量"下进行如下配置: (1)新建->变量名:JAVA_HOME变量值 C:\Program Files\Java\jd ...

  7. ChinaCock让Android App应用不锁屏

    <meta-data android:name="keepScreenOn" android:value="true"> </meta-dat ...

  8. dd 命令的使用

    linux 下dd命令直接清除分区表(不用再fdisk一个一个的删除啦) 分区表是硬盘的分区信息,要删除一个硬盘的所有分区表很麻烦的,需要fdisk一个一个的删除,其实dd命令可直接清除分区信息,当然 ...

  9. 【转】IPV6的地址类型

    http://blog.sina.com.cn/s/blog_8d795a0f01018hiz.html <IPV6的地址类型>IPV6的地址类型 可分为三大类: 1.单播地址 2.组播地 ...

  10. 1.4 Chrome浏览器

    1.4 Chrome浏览器 前言selenium2启动Chrome浏览器是需要安装驱动包的,但是不同的Chrome浏览器版本号,对应的驱动文件版本号又不一样,如果版本号不匹配,是没法启动起来的. ## ...