生产者-消费者(计数)

计数信号量相对互斥锁 的优点:

1,不会出现反复无效解锁,信号量就代表实际的产品空间数量,而不是不管三七二十一先上锁再判断;
2,提高了效率,只要一方一提供资源,另一方马上就可以解锁,响应度更高

1 有两个信号量,要用setall,不是setval

        int ret =semctl(semid,0,SETALL,a);//xx1

2 要while循环不然走一轮就结束了;

另外,还有个容易错的,是信号量的数值是unsigned short不是int!!!

 unsigned short a[2]={10,0};

3 被坑最多的,就是信号量结构体写错。要么写重复了,要么就是格式不对,特别是写重了,用接口判断不出bug

                sopv.sem_num= 0;//xx3  not sopp.sem_num
                sopv.sem_op = 1;//xx3 not sopv.op   not sopv.sem_num

4 sleep1,2,不能反了,不然打印的结果会很懵逼,因为产品多,那就消费者多一点


```
#include <func.h>

int main(){
        int semid=semget(10,2,0600|IPC_CREAT);
        ERROR_CHECK(semid,-1,"semget");
        unsigned short a[2]={10,0};// 0 for food 1 for space
        int ret =semctl(semid,0,SETALL,a);//xx1
        ERROR_CHECK(ret,-1,"semctl");
        if(!fork()){//cus
                struct sembuf sopp,sopv;
                sopp.sem_num = 0;
                sopp.sem_op = -1;
                sopp.sem_flg = SEM_UNDO;
                sopv.sem_num = 1;
                sopv.sem_op = 1;
                sopv.sem_flg = SEM_UNDO;
                while(1){//xx2
                        printf("i am customer ,food :%d , space : %d \n",semctl(semid,0,GETVAL),semctl(semid,1,GETVAL));
                        ret =   semop(semid,&sopp,1);
                        ERROR_CHECK(ret,-1,"semop");
                        printf("eatting..\n");
                        ret =   semop(semid,&sopv,1);
                        ERROR_CHECK(ret,-1,"semop");
                        printf("i am customer ,food :%d , space : %d \n",semctl(semid,0,GETVAL),semctl(semid,1,GETVAL));
                        sleep(1);//xx4
                }
        }else{
                struct sembuf sopp,sopv;
                sopp.sem_num = 1;
                sopp.sem_op = -1;
                sopp.sem_flg = SEM_UNDO;
                sopv.sem_num= 0;//xx3  not sopp.sem_num
                sopv.sem_op = 1;//xx3 not sopv.op   not sopv.sem_num
                sopv.sem_flg = SEM_UNDO;
                while(1){
                        printf("i am producer,food:%d,spce :%d\n",semctl(semid,0,GETVAL),semctl(semid,1,GETVAL));
                        ret =   semop(semid,&sopp,1);
                        ERROR_CHECK(ret,-1,"semop");
                        printf("i am producing .. \n");
                        ret =   semop(semid,&sopv,1);
                        ERROR_CHECK(ret,-1,"semop");
                        printf("i am producer ,food :%d , space : %d \n",semctl(semid,0,GETVAL),semctl(semid,1,GETVAL));
                        sleep(2);//xx4
                }
                wait(NULL);
        }
        return 0;
}
```
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,135评论 6 13
  • 在上篇中,我们已经讨论过如何去实现一个 Map 了,并且也讨论了诸多优化点。在下篇中,我们将继续讨论如何实现一个线...
    一缕殇流化隐半边冰霜阅读 7,677评论 5 41
  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 9,051评论 0 13
  • Q:为什么出现多线程? A:为了实现同时干多件事的需求(并发),同时进行着下载和页面UI刷新。对于处理器,为每个线...
    幸福相依阅读 1,608评论 0 2
  • (一) 在一片望不到边的大海上。一艘大船正在平稳的向前航行着。海上的清晨到处弥漫着浓雾,也不知道大船靠着什么的维持...
    小罗_19ac阅读 152评论 1 1