python进程间通信

python进程间通信:队列,grpc, thrift常用的

队列

在python中,多个线程之间的数据是共享的,多个线程进行数据交换的时候,不能够保证数据的安全性和一致性,所以当多个线程需要进行数据交换的时候,队列就出现了,队列可以完美解决线程间的数据交换,保证线程间数据的安全性和一致性

三种

queue.Queue() 先进先出

queue.LifoQueue() 先进后出

queue.PriorityQueue(maxsize) 优先级

queue.qsuze() 返回当前队列中元素个数
queue.empty() 判断是否为空,返回True  or False
queue.full()  判断队列是否满了, 返回boolean
queue.get([block], timeout) 获取队列
queue.put(item, timeout)  写入 队列,
queue.join()    阻塞调用线程,直到队列中所有任务被处理掉
queue.task_done()  向任务已完成的队列发送一个信号

多进程自带的Queue

Queue()方法相当于第三方,把进程A的数据序列化后传给进程B反序列化得到数据。并不是一个共享的变量。而是实现了数据的传递。

from multiprocessing import Process, Queue
import time
def write_task(q):
    if not q.full():
        for i in range(5):
            message = "消息" + str(i)
            q.put(message)
            print("写入", message)

def read_task(q):
    time.sleep(1)
    while not q.empty():
        print("读取: %s" % q.get(True, 2))

if __name__ == "__main__":
    q= Queue()
    pw = Process(target=write_task, args=(q,))
    pr = Process(target=read_task, args=(q,))
    pw.start()
    pr.start()

管道通信:

Pipe([duplex]): 在进程之间创建一条管道,并返回元组(conn1, conn2), 其中conn1,conn2表示管道两端的连接对象

from multiprocessing import Process,Pipe
conn1, conn2= Pipe()
#默认全双工
#如果将duplex射成False,conn1只能用于接收,conn2只能用于发送。
主要方法:

conn.recv(): 如果没有消息可接收,recv方法会一直阻塞。如果连接的另外一端已经关闭,那么recv方法会抛出EOFError。
conn.send(obj): 通过连接发送数据。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云中烤飞鸟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值