Python的互斥锁与信号量

系统 1369 0

并发与锁

  • a. 多个线程共享数据的时候,如果数据不进行保护,那么可能出现数 据不一致现象,使用锁,信号量、条件锁
    • b.
      • c. 互斥锁
        1. 互斥锁,是使用一把锁把代码保护起来,以牺牲性能换取代码的安全性,那么Rlock后 必须要
        relase 解锁 不然将会失去多线程程序的优势
        2. 互斥锁的基本使用规则:
                                1 
                                
                                  import
                                
                                
                                   threading
        
                                
                                2 
                                
                                  #
                                
                                
                                   声明互斥锁
                                
                                
        3 lock=
                                
                                  threading.Rlock();
        
                                
                                4 
                                
                                  def
                                
                                 handle(sid):
                                
                                  #
                                
                                
                                   功能实现代码
                                
                                
        5 lock.acquire() 
                                
                                  #
                                
                                
                                  加锁
                                
                                
        6 
                                
                                  #
                                
                                
                                   writer codeing
                                
                                
        7 lock.relase() 
                                
                                  #
                                
                                
                                  释放锁
                                
                              
        8
        信号量:
        1. 调用relarse()信号量会+1 调用 acquire() 信号量会-1
        a. 可以理解为对于临界资源的使用,以及进入临界区的判断条件
        2. semphore() :当调用relarse()函数的时候 单纯+1 不会检查信号量的上限情况。 初
        始参数为0
        3. boudedsemphore():边界信号量 当调用relarse() 会+1 , 并且会检查信号量的上
        限情况。不允许超过上限
        a. 使用budedsemaphore时候不允许设置初始为0,将会抛出异常
        b. 至少设置为1 ,如consumer product 时候应该在外设置一个变
        量,启动时候对变量做判断,决定使不使用acquier
        4. 信号量的基本使用代码:
                                1 
                                
                                  #
                                
                                
                                   声明信号量:
                                
                                
        2 sema=threading.Semaphore(0); 
                                
                                  #
                                
                                
                                  无上限检查
                                
                                
        3 sema=threading.BuderedSeamphore(1) 
                                
                                  #
                                
                                
                                  有上限检查设置
                                
                                
        4 5
                                
                                  
        apple
                                
                                =1
        6 
                                
                                  def
                                
                                
                                   consumner():
        
                                
                                7 seam.acquire(); 
                                
                                  #
                                
                                
                                   ‐1
                                
                                
        8 9
        
                                
                                  if
                                
                                 apple==1
                                
                                  :
        
                                
                                10 
                                
                                  pass
                                
                                
        11 
                                
                                  else
                                
                                : sema2.release();
                                
                                  #
                                
                                
                                  + 1
                                
                                
        12 
                                
                                  def
                                
                                
                                   product():
        
                                
                                13 seam.relarse(); 
                                
                                  #
                                
                                
                                   +1
                                
                                
        14 
                                
                                  if
                                
                                 apple==1
                                
                                  :
        
                                
                                15 
                                
                                  pass
                                
                                
        16 
                                
                                  else
                                
                                
                                  :
        
                                
                                17 
                                
                                  print
                                
                                (
                                
                                  "
                                
                                
                                  消费:
                                
                                
                                  "
                                
                                
                                  ,apple);
        
                                
                                18 
                                



      • 全部的代码:
      •                         
                                  #
                                
                                
                                   -*- coding: utf-8 -*-
                                
                                
                                  """
                                
                                
                                  
        Created on Mon Sep  9 21:49:30 2019
        
        @author: DGW-PC
        
                                
                                
                                  """
                                
                                
                                  #
                                
                                
                                   信号量解决生产者消费者问题
                                
                                
                                  import
                                
                                
                                   random;
        
                                
                                
                                  import
                                
                                
                                   threading;
        
                                
                                
                                  import
                                
                                
                                   time;
        
        
                                
                                
                                  #
                                
                                
                                   声明信号量
                                
                                
        sema=threading.Semaphore(0);
                                
                                  #
                                
                                
                                   必须写参数 0 表示可以使用数
                                
                                
        sema2=threading.BoundedSemaphore(1
                                
                                  );
        
        apple
                                
                                =1
                                
                                  ;
        
        
                                
                                
                                  def
                                
                                 product():
                                
                                  #
                                
                                
                                  生产者
                                
                                
                                  global
                                
                                
                                   apple;
            apple
                                
                                =random.randint(1,100
                                
                                  );
            time.sleep(
                                
                                3
                                
                                  );
            
                                
                                
                                  print
                                
                                (
                                
                                  "
                                
                                
                                  生成苹果:
                                
                                
                                  "
                                
                                
                                  ,apple);
            
                                
                                
                                  #
                                
                                
                                  sema2.release(); # +1
                                
                                
                                  if
                                
                                 apple==1
                                
                                  :
                 
                                
                                
                                  pass
                                
                                
                                  else
                                
                                : sema2.release();
                                
                                  #
                                
                                
                                  + 1 
                                
                                
                                  def
                                
                                
                                   consumer():
            
                                
                                
                                  print
                                
                                (
                                
                                  "
                                
                                
                                  等待
                                
                                
                                  "
                                
                                
                                  );
            sema2.acquire();
                                
                                
                                  #
                                
                                
                                   -1
                                
                                
                                  if
                                
                                 apple==1
                                
                                  :
                
                                
                                
                                  pass
                                
                                
                                  else
                                
                                
                                  :        
                
                                
                                
                                  print
                                
                                (
                                
                                  "
                                
                                
                                  消费:
                                
                                
                                  "
                                
                                
                                  ,apple);
            
        
        threads
                                
                                =
                                
                                  [];
        
        
                                
                                
                                  for
                                
                                 i 
                                
                                  in
                                
                                 range(1,3
                                
                                  ):
            t1
                                
                                =threading.Thread(target=
                                
                                  consumer);
            t2
                                
                                =threading.Thread(target=
                                
                                  product);
            t1.start();
            t2.start();
            threads.append(t1);
            threads.append(t2);
        
                                
                                
                                  for
                                
                                 x 
                                
                                  in
                                
                                
                                   threads:
            x.join();
        
            
            
                                
                              

         


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论