zoukankan      html  css  js  c++  java
  • 进程2

    管道:

    Conn1,conn2 = Pipe()

    Conn1.recv()

    Conn1.send()

    数据接收一次就没有了

    事件:

    E = Event()  #初识状态是false

    E.wait()  当事件对象e的状态为false的时候,wait的地方会阻塞程序,当对象状态为true的时候,直接在这个wait地方继续往下执行

    E.set()  将事件对象的状态改为true,

    E.is_set() 查看状态

    E.clear()  将事件对象的状态改为false

    信号量:

    S = semphore(4),内部维护了一个计数器,acquire-1,release+1,0的时候,其他的进程都要在acquire之前等待

    S.acquire()

    需要锁住的代码

    S.release()

    进程池(*****)

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

    进程池:

    Map:异步提交任务,并且传参需要可迭代类型的数据,自带closejoin功能

    Res = Apply(f1,args=(i,))  #同步执行任务,必须等任务执行结束才能给进程池提交下一个任务,可以直接拿到返回结果res

    Res_obj = Apply_async(f1,args=(i,))  #异步提交任务,可以直接拿到结果对象,从结果对象里面拿结果,要用get方法,get方法会阻塞程序,没有拿到结果会一直等待

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

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

    回调函数:

     Apply_async(f1,args=(i,),callback=function)  #将前面f1这个任务的返回结果作为参数传给callback指定的那个function函数

  • 相关阅读:
    转换方法
    数组去重
    js常见兼容
    封装cookie
    常用函数封装
    手绘 代码
    Python变量和数据类型,类型转换
    语句块的概念及注释符的使用
    ipython和pip,模块安装方法
    第一个python程序
  • 原文地址:https://www.cnblogs.com/heheda123456/p/10264049.html
Copyright © 2011-2022 走看看