模拟PV操作同步机构,且用PV操作解决生产者——消费者问题。(2)

2018-11-20 18:43

}

}

wakeup(2);//唤醒消费进程

ready->breakp=pc; //保存断点

void block(int s){//阻塞函数的定义

link p; int num1=0; int num2=0;

if(s==1){//生产进程 }

else{//消费进程

strcpy(c1->state,\strcpy(c1->reason,\

strcpy(p1->state,\改变状态 strcpy(p1->reason,\说明原因 p=b_s1; while(p){ }

if(!b_s1)

b_s1=p1; num1++;

p=p->next;//p的值为NULL,表示队尾

else

p=p1;

p1->next=NULL;

printf(\生产进程阻塞了!\\n\ready->breakp=pc; //保存断点

ready=ready->next;//在就绪队列中去掉,指向下一个 num1++;

}

p=b_s2; while(p){

num2++;

p=p->next;//p的值为NULL,表示队尾

} if(!b_s2)

b_s2=c1;

else

p=c1;

ready->breakp=pc; //保存断点

ready=ready->next;//在就绪队列中去掉,指向下一个 c1->next=NULL;

printf(\消费进程阻塞了!\\n\num2++;

}

printf(\阻塞的生产进程个数为:%d\\n\ printf(\阻塞的消费进程个数为:%d\\n\

void wakeup(int s){//唤醒函数的定义

link p; link q=ready;

if(s==1){ //唤醒b_s1队首进程,生产进程队列

p=b_s1;

b_s1=b_s1->next;//阻塞指针指向下一个阻塞进程 strcpy(p->state,\strcpy(p->reason,\while(q)//插入就绪队列

q=q->next;

q=p;

}

}

p->next=NULL;

printf(\生产进程唤醒了!\\n\

else{ //唤醒b_s2队首进程,消费进程队列 }

p=b_s2;

b_s2=b_s2->next;//阻塞指针指向下一个阻塞进程 strcpy(p->state,\strcpy(p->reason,\while(q->next)//插入就绪队列

q=q->next;

q->next=p; p->next=NULL;

printf(\消费进程唤醒了!\\n\

void control() //处理器调度程序 {

link p=ready; int rd; int num=0;

if(ready==NULL) //若无就绪进程,结束

while(p) //统计就绪进程个数 {

num++;

p=p->next;//最终p变为NULL

return;

}

}

printf(\就绪进程个数为:%d\\n\

time_t t;

srand((unsigned) time(&t)); rd=rand()%num;//随机函数产生随机数 if(rd==1){ } else

strcpy(ready->state,\p=ready;

ready=ready->next; ready->next=p; p->next=NULL;

strcpy(ready->state,\

strcpy(ready->next->state,\

pc=ready->breakp;

void processor(){ //模拟处理器指令执行

if(strcmp(ready->name,\当前进程为生产者

switch(pc) {

case 0://produce

printf(\生产者生产了字符%c\\n\rec_p[rp1]=str[sp];//添加到生产记录

sp=(sp+1)%len;

pc++;

ready->breakp=pc; //保存断点 break;

case 1: //p(s1)

pc++; p(1); break;

case 2: //put

buffer[in]=rec_p[rp1]; //放到缓冲区

printf(\字符成功入驻空缓存!\\n\rp1++;

in=(in+1)%BUF; pc++;

ready->breakp=pc; //保存断点 break;

case 3: //v(s2)

pc++;

printf(\释放一个s2信号\\n\v(2); break;

case 4://goto01

printf(\生产进程goto 0 操作\\n\pc=0;

count--; //剩余字符个数减1

printf(\剩余字符count=%d个\\n\ready->breakp=pc; //保存断点

if(count<=0){ //生产结束 }

printf(\生产者结束生产!\\n\strcpy(p1->state,\strcpy(p1->reason,\ready->breakp=-1;

ready=ready->next;//在就绪队列中去掉


模拟PV操作同步机构,且用PV操作解决生产者——消费者问题。(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:2014道德讲堂活动总结

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: