python学习笔记——多进程中的锁Lock
1 进程锁
python编程中,引入了对象互斥锁的概念,来保证共享数据操作的完整性。
每个对象都对应于一个可称为“互斥锁”的标记,这个标记用来保证在任一时刻,只能有一线程访问对象。
在python中我们使用 multiprocessing.Lock 和 threading.Lock 可以实现进程锁控制。
2 示例
2.1 acquire()加锁
from multiprocessing import Lock
lock = Lock()
lock.acquire() #加锁
lock.acquire()#此时阻塞在该函数处
print("lock...")
运行,并没有打印出lock...,函数阻塞。
当一个进程加锁,另外一个进程也加锁时,则会发生此函数运行阻塞。
当一个进程加锁,另外一个进程不加锁时,则另一个函数没有任何限制。
2.2 release()解锁
from multiprocessing import Lock
lock = Lock()
lock.acquire()
lock.release()
print("lock...")
运行:输出 lock...
2.3 加锁与解锁之间的区别
lock.release()解锁后显示
from multiprocessing import Lock
lock = Lock()
lock.acquire()
lock.release()
# lock.acquire()
with lock:
print("lock...")
运行:
lock...
lock.acquire()加锁后显示
from multiprocessing import Lock
lock = Lock()
lock.acquire()
lock.release()
lock.acquire()
with lock:
print("lock...")
运行,一直处于阻塞状态,没有输出
此时运行,阻塞在with语句,with 语句运行完毕会自动解锁
2.4 综合应用
from multiprocessing import Process,Lock
import sys,time
def worker1(stream):
lock.acquire()
for i in range(5):
time.sleep(1)
stream.write('Lock acquired via\n')
lock.release()
def worker2(stream):
with lock:
for i in range(5):
time.sleep(1)
stream.write("lock acquired directly\n")
lock = Lock()
w1 = Process(target = worker1,args = (sys.stdout,))
w2 = Process(target = worker2,args = (sys.stdout,))
w1.start()
w2.start()
w1.join()
w2.join()
worker1 和worker2 都加锁时,两个进程会顺序执行,也即运行完成一个进程再运行第二个进程;当两个进程中最多只有一个进程加锁时,则不会出现进程阻塞的情况。
两个子进程的运行前后不区分,但是一旦一个子程序运行,另一个子程序就会被阻塞,但具体那个子程序先运行,不能完全确定
python学习笔记——多进程中的锁Lock的更多相关文章
- python学习笔记——多进程中共享内存Value & Array
1 共享内存 基本特点: (1)共享内存是一种最为高效的进程间通信方式,进程可以直接读写内存,而不需要任何数据的拷贝. (2)为了在多个进程间交换信息,内核专门留出了一块内存区,可以由需要访问的进程将 ...
- python学习笔记—— 多进程中的 孤儿进程和僵尸进程
1 基本概述 1.1 孤儿进程和僵尸进程 父进程创建子进程后,较为理想状态是子进程结束,父进程回收子进程并释放子进程占有的资源:而实际上,父子进程是异步过程,两者谁先结束是无顺的,一般可以通过父进程调 ...
- Python 学习笔记 多进程 multiprocessing--转载
本文链接地址 http://quqiuzhu.com/2016/python-multiprocessing/ Python 解释器有一个全局解释器锁(PIL),导致每个 Python 进程中最多同时 ...
- python 学习笔记 多进程
要让python程序实现多进程,我们先了解操作系统的相关知识 Unix/Linux操作系统提供了一个fork()系统调用,他非常特殊,普通的函数调用,调用一次,返回一次,但是fork调用一次, 返回两 ...
- python学习笔记-多进程
multiprocessing from multiprocessing import Process import time def f(name): time.sleep(2) print('he ...
- Python学习笔记6-Python中re(正则表达式)模块学习
今天学习了Python中有关正则表达式的知识.关于正则表达式的语法,不作过多解释,网上有许多学习的资料.这里主要介绍Python中常用的正则表达式处理函数. re.match re.match 尝试从 ...
- python学习笔记——爬虫中提取网页中的信息
1 数据类型 网页中的数据类型可分为结构化数据.半结构化数据.非结构化数据三种 1.1 结构化数据 常见的是MySQL,表现为二维形式的数据 1.2 半结构化数据 是结构化数据的一种形式,并不符合关系 ...
- python学习笔记——多进程二 进程的退出
1 进程的退出函数的基础语法 1.1 进程的退出函数 进程的退出含有有os._exit([status])和sys.exit([status])两种,从数据包来看,该退出模块仅在linux或者unix ...
- python学习笔记——多进程一 基础概念
1 进程 进程:程序的一次(从开始到结束)执行过程,属于一个动态过程.是系统进行资源分配和调度的基本单位. 程序:指的是一个文件,磁盘中可执行的代码.属于一个静态文件 注:进程运行时需要把程序加载如内 ...
随机推荐
- require.js 最佳实践
require.js是一个js库,相关的基础知识,前面转载了两篇博文:Javascript模块化编程(require.js), Javascript模块化工具require.js教程,RequireJ ...
- OkHttp 官方Wiki之【使用案例】
原文位置:https://github.com/square/okhttp/wiki/Recipes Recipes 食谱/知识点清单 We've written some recipes that ...
- Android程序apk反编译破解方法
简短不割了,我们直接奔主题吧. 把apktool-install-windows-r05-ibot文件里的两个文件剪切到apktool1.5.1目录. 新建一个文件夹把需要破解的apk应用程序放进去. ...
- 历尽折腾,终于把Unity3D 的demo发布安卓啦(问题)
只要碰到两个比较蛋疼的问题: 1. Error generating final archive: Debug certificate expired on **** 从字面了解,是由于Debug证书 ...
- 【Android 百度地图实战】1.构建一个基础的地图页面
虽然很简单,但是还是有些细节要注意的,小错误搞死人啊,具体步骤官网API已提供,地址在这. 效果图如下: 主要代码: package yc.example.yc_ebaidumap; import a ...
- 理解进程调度时机跟踪分析进程调度与进程切换的过程(Linux)
----------------------------------------------------------------------------------- 理解进程调度时机跟踪分析进程调度 ...
- spring mvc实现登录验证码
一.实现图形验证码的基础类 VerifyCodeUtils.java,这个类是从网上摘抄的~ package com.comp.common; import java.awt.Color; impor ...
- 电脑PE系统工具
自己收集的一些PE电脑维护工具 电脑店PE工具 http://u.diannaodian.com/ 通用PE工具箱 http://www.tongyongpe.com/ 大白菜PE工具 http:// ...
- jQuery之前端国际化jQuery.i18n.properties[转]
http://www.ibm.com/developerworks/cn/web/1305_hezj_jqueryi18n/ jQuery.i18n.properties是一款轻量级的jQuery国际 ...
- Httpclient 4, error 302. How to redirect?
http://stackoverflow.com/questions/3658721/httpclient-4-error-302-how-to-redirect DefaultHttpClient ...