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 进程 进程:程序的一次(从开始到结束)执行过程,属于一个动态过程.是系统进行资源分配和调度的基本单位. 程序:指的是一个文件,磁盘中可执行的代码.属于一个静态文件 注:进程运行时需要把程序加载如内 ...
随机推荐
- [13] 弧面(Arc)图形的生成算法
顶点数据的生成 bool YfBuildArcVertices ( Yreal radius, Yreal degree, Yreal height, Yuint slices, Yuint stac ...
- HashTable HashMap HashSet区别(java)
Hashtable: 1. key和value都不许有null值 2. 使用enumeration遍历 3. 同步的,每次只有一个线程能够访问 4. 在java中Hashtable是H大写,t小写,而 ...
- Linked List Cycle leetcode II java (寻找链表环的入口)
题目: Given a linked list, return the node where the cycle begins. If there is no cycle, return null. ...
- BigDecimal 小数 浮点数 精度 财务计算
简介 float和double类型的使用局限: 单精度浮点型变量float可以处理6~7位有效数,双精度浮点型变量double可以处理15~16位有效数,在实际应用中,如果需要对更大或者更小的数进行运 ...
- 以AVL树为例理解二叉树的旋转(Rotate)操作
树旋转是在二叉树中的一种子树调整操作, 每一次旋转并不影响对该二叉树进行中序遍历的结果. 树旋转通常应用于需要调整树的局部平衡性的场合. 树旋转包括两个不同的方式, 分别是左旋转和右旋转. 两种旋转呈 ...
- 【NodeJS】nvm、npm、node安装、使用、淘宝源设置等资料
NodeJS-安装使用淘宝源 管理 node 版本,选择 nvm 还是 n? - WEB前端 - 伯乐在线 creationix/nvm: Node Version Manager - Simple ...
- 【Android】自己定义控件实现可滑动的开关(switch)
~转载请注明来源:http://blog.csdn.net/u013015161/article/details/46704745 介绍 昨天晚上写了一个Android的滑动开关, 即SlideSwi ...
- ThinkPHP3.2 新bug ReadHtmlCache 支持不区分大写和小写的函数
报错提示: Fatal error: Function name must be a string in D:\wwwroot\zbphp.com\ThinkPHP\Library\Behavior\ ...
- Hibernate(十四)缓存
一.什么是缓存 缓存是介于应用程序和永久必数据存储源之间,目的是为了降低应用程序直接读写永久必数据存储源的频率,从而提高运行性能 缓存通常是在内存中的如: Office中的Word.excel Hib ...
- Java从零开始学十七(简单工厂)
简单工厂的实现 实现一个计算器:要求输入2个数,和运算符,得到结果 Operation类 package com.pb.demo1; public class Operation { private ...