python互斥锁、加锁、同步机制、异步通信知识总结


Posted in Python onFebruary 11, 2018

某个线程要共享数据时,先将其锁定,此时资源的状态为“锁定”,其他线程不能更改;直到该线程释放资源,将资源的状态变成“非锁定”,其他的线程才能再次锁定该资源。互斥锁保证了每次只有一个线程进入写入操作,从而保证了多线程情况下数据的正确性。

采用f_flag的方法效率低

创建锁

mutex=threading.Lock()

锁定

mutex.acquire([blocking])#里面可以加blocking(等待的时间)或者不加,不加就会一直等待(堵塞)

释放

mutex.release()

import threading 
from threading import Thread 
from threading import Lock 
import time 
 
thnum=0 
#两个线程都在抢着对这个锁进行上锁,如果有一方成功上锁,那么导致另外一方会堵塞(一直等待),到这个锁被解开为之 
class MyThread(threading.Thread): 
  def run(self): 
    mutex.acquire() 
    for i in range(10000): 
      global thnum 
      thnum+=1   
    print(thnum) 
    mutex.release()  
def test(): 
  global thnum 
  mutex.acquire() #等待可以上锁,通知而不是轮训,没有占用CPU 
  for i in range(10000): 
    thnum+=1 
  print(thnum) 
  mutex.release()#解锁 
mutex=Lock() 
if __name__=='__main__': 
  t=MyThread() 
  t.start() 
 
#创建一把互斥锁,默认是没有上锁的 
 
thn=Thread(target=test) 
thn.start() 
 
''''' 
10000 
20000 
'''

只要一上锁,由多任务变为单任务,相当于只有一个线程在运行。

下面的代码相对上面加锁的时间变短了

import threading 
from threading import Thread 
from threading import Lock 
import time 
 
thnum=0 
#两个线程都在抢着对这个锁进行上锁,如果有一方成功上锁,那么导致另外一方会堵塞(一直等待),到这个锁被解开为之 
class MyThread(threading.Thread): 
  def run(self): 
    for i in range(10000): 
      mutex.acquire() 
      global thnum 
      thnum+=1 
      mutex.release()#释放后,都开始抢,这样上锁的时间变短  
    print(thnum) 
     
def test(): 
  global thnum 
  for i in range(10000): 
    mutex.acquire() 
    thnum+=1 
    mutex.release()#解锁 
  print(thnum) 
mutex=Lock() 
if __name__=='__main__': 
  t=MyThread() 
  t.start() 
 
#创建一把互斥锁,默认是没有上锁的 
 
thn=Thread(target=test) 
thn.start() 
 
''''' 
10000 
20000 
'''

只有必须加锁的地方才加锁

同步:按照预定的先后顺序执行

一个运行完后,释放下一个,下一个锁定后运行,再释放下一个,下一个锁定后,运行后释放下一个..... 释放第一个

异步:

#异步的实现 
from multiprocessing import Pool 
import time 
import os 
 
#getpid()获取当前进程的进程号 
#getppid()获取当前进程的父进程号 
 
def test():#子进程 
  print("----进程池中的进程-----pid=%d,ppid=%d --"%(os.getpid(),os.getppid())) 
  for i in range(3): 
    print("-----%d----"%i) 
    time.sleep(1) 
  return "over" #子进程执行完后返回给操作系统,返回给父进程 
 
def test2(args): 
  print("-----callback func----pid=%d"%os.getpid())#主进程调用test2 
  print("------callback func---args=%s"%args) 
 
def main(): 
  pool=Pool(3) 
  pool.apply_async(func=test,callback=test2)#回调 
  time.sleep(5)#收到func进程结束后的信号后,执行回调函数test2 
 
  print("----主进程-pid = %d"%os.getpid()) 
 
if __name__=="__main__": 
  #main() 
  pool=Pool(3) 
  pool.apply_async(test,callback=test2)#回调 
  time.sleep(5)#收到func进程结束后的信号后,执行回调函数test2 
 
  print("----主进程-pid = %d"%os.getpid()) 
 
'''''显示结果不太正确,应该先运行test呀,再运行test2 
-----callback func----pid=7044 
------callback func---args=over 
----主进程-pid = 7044 
----进程池中的进程-----pid=3772,ppid=7044 -- 
-----0---- 
-----1---- 
-----2---- 
'''
Python 相关文章推荐
基于Python实现的扫雷游戏实例代码
Aug 01 Python
Ubuntu 14.04+Django 1.7.1+Nginx+uwsgi部署教程
Nov 18 Python
Python删除Java源文件中全部注释的实现方法
Aug 30 Python
基于使用paramiko执行远程linux主机命令(详解)
Oct 16 Python
Python socket实现简单聊天室
Apr 01 Python
对python append 与浅拷贝的实例讲解
May 04 Python
python实现画一颗树和一片森林
Jun 25 Python
Python+OpenCV感兴趣区域ROI提取方法
Jan 10 Python
Python 实现的 Google 批量翻译功能
Aug 26 Python
Python 正则表达式爬虫使用案例解析
Sep 23 Python
Python文件路径名的操作方法
Oct 30 Python
手残删除python之后的补救方法
Jun 26 Python
python编程嵌套函数实例代码
Feb 11 #Python
Tensorflow的可视化工具Tensorboard的初步使用详解
Feb 11 #Python
Django自定义manage命令实例代码
Feb 11 #Python
Python实现的购物车功能示例
Feb 11 #Python
python PyTorch参数初始化和Finetune
Feb 11 #Python
Python装饰器用法示例小结
Feb 11 #Python
python PyTorch预训练示例
Feb 11 #Python
You might like
php使用fopen创建utf8编码文件的方法
2014/10/31 PHP
PHP常见的6个错误提示及解决方法
2016/07/07 PHP
php_pdo 预处理语句详解
2016/11/21 PHP
php 中奖概率算法实现代码
2017/01/25 PHP
Javascript之旅 对象的原型链之由来
2010/08/25 Javascript
JavaScript中的View-Model使用介绍
2011/08/11 Javascript
Extjs407 getValue()和getRawValue()区别介绍
2013/05/21 Javascript
jquery js 获取时间差、时间格式具体代码
2013/06/05 Javascript
js 距离某一时间点时间是多少实现代码
2013/10/14 Javascript
使用JavaScript修改浏览器URL地址栏的实现代码
2013/10/21 Javascript
JQuery表单验证插件EasyValidator用法分析
2014/11/15 Javascript
node.js中的fs.lstatSync方法使用说明
2014/12/16 Javascript
使用 electron 实现类似新版 QQ 的登录界面效果(阴影、背景动画、窗体3D翻转)
2018/10/23 Javascript
mui js控制开关状态、修改switch开关的值方法
2019/09/03 Javascript
python下如何让web元素的生成更简单的分析
2008/07/17 Python
一步步教你用Python实现2048小游戏
2017/01/19 Python
Python创建二维数组实例(关于list的一个小坑)
2017/11/07 Python
python爬虫之模拟登陆csdn的实例代码
2018/05/18 Python
python读取目录下所有的jpg文件,并显示第一张图片的示例
2019/06/13 Python
Python依赖包整体迁移方法详解
2019/08/15 Python
Python中的单下划线和双下划线使用场景详解
2019/09/09 Python
解决pytorch报错:AssertionError: Invalid device id的问题
2020/01/10 Python
pycharm通过ssh连接远程服务器教程
2020/02/12 Python
python3连接MySQL8.0的两种方式
2020/02/17 Python
Django 自定义权限管理系统详解(通过中间件认证)
2020/03/11 Python
详解Django配置JWT认证方式
2020/05/09 Python
美国在线乐器和设备商店:Musician’s Friend
2018/07/06 全球购物
美国相机和电子产品零售商:Beach Camera
2020/11/26 全球购物
资产评估专业大学生求职信
2013/09/29 职场文书
毕业生医学检验求职信
2013/10/16 职场文书
食堂个人先进事迹
2014/01/22 职场文书
培训讲师岗位职责
2014/04/13 职场文书
省级优秀毕业生主要事迹
2014/05/29 职场文书
征兵宣传标语
2014/06/20 职场文书
先进教育工作者事迹材料
2014/12/23 职场文书
详解java如何集成swagger组件
2021/06/21 Java/Android