复习之锁,队列,进程线程池,协程

一,死锁(了解)

  即使你知道如何抢锁,释放锁,业绩有可能造成程序的死锁现象

  后续我们在写项目的时候,也不会在自己去处理锁的问题,都是底层封装好的 (码农搬砖)、

二,递归锁(了解)

  他是一把互斥锁,但是他可以被第一个抢到它的人连续的acquire 和release  每acquire一次内部有一个引用计数加一,每release一次内部引用计数减一

  只要引用计数部位0,永远无法被其他人控制

三,信号量(了解)

  在不同的领域和知识阶段可能对应不同的概念

  如果将互斥锁比喻成一个厕所,那么信号量就是多个厕所

四,event事件(了解)

  一些线程/进程等待另外一些线程/进程 发送可以运行的信号才开始运行

  

from threading import Event
e=Event()

#等待
e.wait()

#发送信号
e.set()

 

五,各种队列

  (1),queue 队列,先进先出

    

q=queue.Queue()
q.put()
q.get()
e.get_nowat()
q.full()
q.emty()

 (2) 后进先出 LifoQueue

  

q=queue.LifoQueue()
q.put()
q.get()

(3)优先级PriorityQueue()

  

q=queue.priorityQueue
q.put((10,'data')) #元祖里面第一个参数是数字,并且支持负数,越小优先级越高

六,进程池/线程池

  池的概念

    他的出现是为了保证计算机硬件的安全

    降低了程序的运行效率,但是保证了计算机硬件安全

   # 进程池线程池都不要我们自己去造,直接使用封装的模块

  

  

 

  

  

 

posted @ 2023-05-08 09:26  请别对我太好  阅读(7)  评论(0编辑  收藏  举报