91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

      手機站
      千鋒教育

      千鋒學習站 | 隨時隨地免費學

      千鋒教育

      掃一掃進入千鋒手機站

      領取全套視頻
      千鋒教育

      關注千鋒學習站小程序
      隨時隨地免費學習課程

      當前位置:首頁  >  技術干貨  > python 管道

      python 管道

      來源:千鋒教育
      發(fā)布人:xqq
      時間: 2023-11-08 02:02:48 1699380168

      創(chuàng)建管道的類:

      Pipe([duplex]):在進程之間創(chuàng)建一條管道,并返回元組(conn1,conn2),其中conn1,conn2表示管道兩端的連接對象,強調一點:必須在產(chǎn)生Process對象之前產(chǎn)生管道

      參數(shù)介紹:

      dumplex:默認管道是全雙工的,如果將duplex射成False,conn1只能用于接收,conn2只能用于發(fā)送。

      frommultiprocessingimportProcess,Pipe

      importtime,os

      defconsumer(p,name):

      left,right=p

      left.close()

      whileTrue:

      try:

      baozi=right.recv()

      print('%s收到包子:%s'%(name,baozi))

      exceptEOFError:

      right.close()

      break

      defproducer(seq,p):

      left,right=p

      right.close()

      foriinseq:

      left.send(i)

      #time.sleep(1)

      else:

      left.close()

      if__name__=='__main__':

      left,right=Pipe()

      c1=Process(target=consumer,args=((left,right),'c1'))

      c1.start()

      seq=(iforiinrange(10))

      producer(seq,(left,right))

      right.close()

      left.close()

      c1.join()

      print('主進程')

      注意:生產(chǎn)者和消費者都沒有使用管道的某個端點,就應該將其關閉,如在生產(chǎn)者中關閉管道的右端,在消費者中關閉管道的左端。如果忘記執(zhí)行這些步驟,程序可能再消費者中的recv()操作上掛起。管道是由操作系統(tǒng)進行引用計數(shù)的,必須在所有進程中關閉管道后才能生產(chǎn)EOFError異常。因此在生產(chǎn)者中關閉管道不會有任何效果,付費消費者中也關閉了相同的管道端點。

      管道可以用于雙向通信,利用通常在客戶端/服務器中使用的請求/響應模型或遠程過程調用,就可以使用管道編寫與進程交互的程序

      frommultiprocessingimportProcess,Pipe

      importtime,os

      defadder(p,name):

      server,client=p

      client.close()

      whileTrue:

      try:

      x,y=server.recv()

      exceptEOFError:

      server.close()

      break

      res=x+y

      server.send(res)

      print('serverdone')

      if__name__=='__main__':

      server,client=Pipe()

      c1=Process(target=adder,args=((server,client),'c1'))

      c1.start()

      server.close()

      client.send((10,20))

      print(client.recv())

      client.close()

      c1.join()

      print('主進程')

      #注意:send()和recv()方法使用pickle模塊對對象進行序列化。

      以上內(nèi)容為大家介紹了python管道,希望對大家有所幫助,如果想要了解更多Python相關知識,請關注IT培訓機構:千鋒教育。

      tags: python培訓
      聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
      10年以上業(yè)內(nèi)強師集結,手把手帶你蛻變精英
      請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
      免費領取
      今日已有369人領取成功
      劉同學 138****2860 剛剛成功領取
      王同學 131****2015 剛剛成功領取
      張同學 133****4652 剛剛成功領取
      李同學 135****8607 剛剛成功領取
      楊同學 132****5667 剛剛成功領取
      岳同學 134****6652 剛剛成功領取
      梁同學 157****2950 剛剛成功領取
      劉同學 189****1015 剛剛成功領取
      張同學 155****4678 剛剛成功領取
      鄒同學 139****2907 剛剛成功領取
      董同學 138****2867 剛剛成功領取
      周同學 136****3602 剛剛成功領取
      相關推薦HOT