ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

管程

2022-08-07 13:33:08  阅读:190  来源: 互联网

标签:count full 互斥 管程 remove item


管程

为什么要引入管程

管程就像是一个类,将信号量与PV操作进行了封装

管程的组成:

  1. 局部于管程的共享数据结构说明

  2. 对该数据结构进行操作的一组过程

  3. 对局部于管程的共享数据设置初始值的语句

  4. 管程要有一个名字

管程的基本特征:

  1. 局部于管程的数据只能被局部于管程的过程所访问(变量私有)。

  2. 一个进程只有调用过程才能进入管程访问共享数据。

  3. 每一次仅仅允许一个进程在管程中执行某一个内部过程。(相当于是互斥了叭)(由编译器负责实现各进程互斥地进入管程中的过程)

管程是用来实现进程互斥和同步的

//用管程解决生产者与消费者问题
//定义管程
monitor ProducerConsumer
    condition full , empty ; //用来实现同步的信号量
    int count  = 0;
    void insert(Intm item){
        if(count == N){
            wait(full); // 相当于是P操作,在这里停着等待唤醒
        }
        count ++;
        insert_item(item);
        if(count == 1)  //如果是第一个插入的
            signal(empty);//将等待的消费者唤醒
    }
    Item remove(){
        if(count  == 0){
            wait(empty);
        }
        count--;
        if(count == N-1)
            signal(full);
        return remove_item();
    }
    end monitor;
//生产者
producer(){
    while(1){
        item = 生产一个产品;
        ProducerConsumer.insert(item);
    }
}

//消费者
consumer(){
    while(1){
        item = ProducerConsumer.remove();
        消费 item;
    }
}

标签:count,full,互斥,管程,remove,item
来源: https://www.cnblogs.com/wuqiu/p/16558915.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有