python day06

一lock
多个进程需要访问共享资源的时候,Lock(锁)可以用来避免访问时的冲突。在这里插入图片描述
二进程通信

import multiprocessing

import os

def func(conn): # conn表示管道类型

print('func',os.getpid(), conn.recv())  # 收到的数据
conn.send(['a', 'b', 'c', 'd', 'e'])  # 发送的数据
conn.close()  # 关闭

if name == “main”:
conn_a, conn_b = multiprocessing.Pipe() # 创建一个管道,有两个口
# print(id(conn_a),id(conn_b))
#print(type(conn_a), type(conn_b)) #multiprocessing.connection.Connection链接,意思就是连接口

#相当于在进程中conn_a,send([‘a’,‘b’,‘c’,‘d’]),发送给conn_b
p = multiprocessing.Process(target=func, args=(conn_a,)).start()
conn_b.send([1, 2, 3, 4, 5, 6, 7]) # 发送数据给conn_a
print(‘mian’,os.getpid(), conn_b.recv())
在这里插入图片描述
全局变量不可以进程共享

import multiprocessing

import os

data = []

def List():
global data
data.append(1)
data.append(2)
data.append(3)
print(‘p’,os.getpid(),data)
if name == ‘main’:
p = multiprocessing.Process(target=List,args=()).start() # 子进程
data.append(‘a’) # 脚本主进程
data.append(‘b’)
data.append(‘c’)
print(‘main’,os.getpid(),data)

‘’’
全局变量不共享
1809 [‘a’, ‘b’, ‘c’]
1810 [1, 2, 3]
‘’’

三Queue对象
exception queue.Empty
对空的 Queue 对象,调用非阻塞的 get() (or get_nowait()) 时,引发的异常。

exception queue.Full
对满的 Queue 对象,调用非阻塞的 put() (or put_nowait()) 时,引发的异常。

queue.put(item, block=True, timeout=None)
将 item 放入队列。如果可选参数 block 是 true 并且 timeout 是 None (默认),则在必要时阻塞至有空闲插槽可用。如果 timeout 是个正数,将最多阻塞 timeout 秒,如果在这段时间没有可用的空闲插槽,将引发 Full 异常。反之 (block 是 false,不等待直接取),如果空闲插槽立即可用,则把 item 放入队列,否则引发 Full 异常 ( 在这种情况下,timeout 将被忽略)

Queue.get(block=True, timeout=None)
从队列中移除并返回一个项目。如果可选参数 block 是 true 并且 timeout 是 None (默认值),则在必要时阻塞至项目可得到。如果 timeout 是个正数,将最多阻塞 timeout 秒,如果在这段时间内项目不能得到,将引发 Empty 异常。反之 (block 是 false) , 如果一个项目立即可得到,则返回一个项目,否则引发 Empty 异常 (这种情况下,timeout 将被忽略)。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值