码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 专题七:PV操作


    一、简单的同步与互斥问题

    ①13年45题
    ②20年45题
    ③17年46题
    ④11年45题






    二、生产者与消费者

    1.单生产者与单消费者

    在这里插入图片描述

    1.生产者与消费者
    
    semaphore empty = 5; //空缓冲区数,初始有5个空缓冲区
    semaphore full = 0;  //产品数,初始缓冲区中没有产品
    semaphore mutex = 1; //互斥锁,生产者与生产者之间、生产者与消费者之间要互斥地访问缓冲区
    
    CoBegin
    {
      Producer()  //生产者进程
      {
    	while(1)
    	{
      		生产一个产品;
    		P(empty);
    		P(mutex);
    		生产者将产品放入缓冲区;
    		V(mutex);
    		V(full); //放入产品后,缓冲区内多了一个产品
    	}
      }
      Consumer() //消费者进程
      {
    	while(1)
    	{
      		P(full);
      		P(mutex);
    		从缓冲区取走一个产品;
     		V(mutex);
      		V(empty);  //取走产品后,多了一个空缓冲区
      		消费产品;
    	}
      }
    }
    CoEnd
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34



    2.多生产者与多消费者

    在这里插入图片描述

    2.多类生产者-多类消费者
    取水果
    
    semaphore mutex = 1;
    semaphore empty = 1;
    semaphore full = 0;
    semaphore apple = 0;
    semaphore orange = 0;
    CoBegin
    {
    	Dad()                    Mom()                  Son()                  Daughter()
    	{                        {                       {                      {
     		while(1)              	while(1)           	while(1)                while(1)
     		{                       {                       {                      {
        	  削苹果;                 剥橘子;                 P(full);                 P(full);
          	  P(empty);               P(empty);                 P(apple);              P(orange);
              P(mutex);               P(mutex);                 P(mutex);              P(mutex);
          	  向盘中放入一个苹果;       向盘中放入一个橘子;     	从盘中取一个苹果;       从盘中取一个橘子;
          	  V(mutex);               V(mutex);                 V(mutex);              V(mutex);
          	  V(full);                V(full);                  V(empty);              V(empty);
          	  V(apple);               V(orange);                吃苹果;                 吃橘子;
      		}                        }                       }                      }
    	}                        }                       }                      }
    }
    CoEnd
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    例题:
    14年47.






    三、哲学家进餐问题

    19年43.

  • 相关阅读:
    Python3 - Docker图像化管理工具之Portainer
    Hacker 资讯|11 月中下旬区块链黑客松活动汇总
    【Linux】【驱动】平台总线模式platform模型的编写,操作LED灯
    React - 高级用法
    Docker基础用法
    Java,自从看了你一眼,就再也无法忘怀
    【前沿技术RPA】 RPA开发人员的日常
    【新三板年报文本分析】第二辑:从pdf链接的列表中批量下载年报文件
    Python 潮流周刊#16:优雅重要么?如何写出 Pythonic 的代码?
    Linux进程等待
  • 原文地址:https://blog.csdn.net/Edward1027/article/details/126077445
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号