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

作者:yanghuatang 时间:2023-10-08 21:17:16 

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

采用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----
'''

来源:http://blog.csdn.net/yanhuatangtang/article/details/75316644

标签:python,互斥锁,加锁,同步机制,异步通信
0
投稿

猜你喜欢

  • 关于多域名COOKIES作用域的问题

    2008-11-18 16:12:00
  • python类的继承实例详解

    2021-04-10 07:22:33
  • FSO无效的过程调用或参数问题

    2010-03-25 21:49:00
  • 自然选择:自然界的颜色与界面设计[译]

    2009-09-19 17:17:00
  • python中format的用法实例详解

    2023-08-03 12:27:28
  • python学习--使用QQ邮箱发送邮件代码实例

    2023-10-29 23:43:59
  • matlab中imadjust函数的作用及应用举例

    2021-09-12 21:34:06
  • pyhon如何把程序打包为whl

    2023-06-16 11:30:48
  • Python字典和集合讲解

    2021-03-05 22:31:14
  • Python在cmd上打印彩色文字实现过程详解

    2022-12-19 07:27:33
  • Python subprocess模块学习总结

    2022-04-29 02:17:40
  • asp清理站点缓存代码

    2008-07-21 12:37:00
  • 简述Asp与XML之间的关系

    2008-04-17 10:46:00
  • Python向Excel中插入图片的简单实现方法

    2022-09-27 21:41:59
  • Django基础之Model操作步骤(介绍)

    2022-04-12 12:17:50
  • Python语言进阶知识点总结

    2022-11-09 01:21:37
  • python实现公司年会抽奖程序

    2022-12-19 15:35:27
  • python爬取”顶点小说网“《纯阳剑尊》的示例代码

    2021-02-14 11:03:35
  • 使用python-opencv读取视频,计算视频总帧数及FPS的实现

    2022-02-03 06:55:34
  • Python 实现数据结构中的的栈队列

    2023-01-24 02:14:33
  • asp之家 网络编程 m.aspxhome.com