操作系统-PV操作的原理和几种常见问题
typedef struct semaphore {
int value;
struct pcb *list; //信号量队列指针
}
void P(semaphore s){
s.value--;
if(s.value<) sleep(s.list); //若信号量值小于0,执行P操作的进程调用sleep(s.list)阻塞自己,被置成等待信号量s状态并移入s信号量队列,转向进程调度程序
}
void V(semaphore s){
s.value++;
if(s.value<=) wakeup(s.list); //若信号量小于等于0,则调用wakeup(s.list)从信号量s队列中释放一个等待信号量s的进程并转换成就绪态,进程则继续运行
}
- 机票问题
int A[m];
Semaphore s = ;
cobegin
process Pi {
int Xi;
Li:按旅客定票要求找到A[j];
P(s);
Xi = A[j];
If (Xi>=) { Xi=Xi-; A[j]=Xi;V(s); 输出一张票;}
else {V(s); 输出票已售完;}
goto Li;
}
coend;
int A[m];
Semaphore s[m]; //每一个航班都有自己的临界区
For (int j=;j<m;i++) s[j] = ;
cobegin
process Pi {
int Xi;
L1:按旅客定票要求找到A[j];
P(s[j]);
Xi = A[j];
If (Xi>=) { Xi=Xi-; A[j]=Xi;V(s[j]); 输出一张票;
} else {V(s[j]); 输出票已售完;}
goto L1;
}
coend;
- 生产者消费者问题
int B;
semaphore sput = ; /* 可以使用的空缓冲区数 */
semaphore sget = ; /* 缓冲区内可以使用的产品数 */
process producer {
L1:
produce a product;
P(sput);
B = product;
V(sget);
goto L1;
}
process consumer {
L2:
P(sget);
product = B;
V(sput);
consume a product;
goto L2;
}
int B[k]; // 共享缓冲区队列
semaphore sput = N; //可以使用的空缓冲区数
semaphore sget = ; //缓冲区内可以使用的产品数
int putptr = getptr = ;
process producer {
L1:produce a product;
P(sput);
B[putptr] = product;
putptr = (putptr + ) mod k;
V(sget);
goto L1;
}
process consumer {
L2:P(sget);
product = B[getptr];
getptr = (getptr + ) mod k;
V(sput);
consume a product;
goto L2;
}
int B[k];
semaphore sput = N; /* 可以使用的空缓冲区数 */
semaphore sget = ; /* 缓冲区内可以使用的产品数 */
int putptr = getptr = ;
semaphore s1 = s2 = ; /* 互斥使用putptr、getptr */
process producer_i {
L1:produce a product;
P(sput);
P(s1);
B[putptr] = product;
putptr = ( putptr + ) mod k;
V(s1);
V(sget);
goto L1;
}
process consumer_j {
L2:P(sget);
P(s2);
Product = B[getptr];
getptr = ( getptr + ) mod k;
V(s2);
V(sput);
consume a product;
goto L2;
}
process consumer_j {
P(mutex1);
for(int i=; i<; i++){
P(full);
P(mutex2);
互斥访问缓冲区;
V(mutex2);
V(empty);
}
V(mutex1);
}
Semaphore sp; /* 盘子里可以放几个水果*/
Semaphore sg1; /* 盘子里有桔子*/
Semaphore sg2; /* 盘子里有苹果*/
sp = ; /* 盘子里允许放入一个水果*/
sg1 = ; /* 盘子里没有桔子*/
sg2 = ; /* 盘子里没有苹果*/
process father {
L1: 削一个苹果;
P(sp);
把苹果放入plate;
V(sg2);
goto L1;
}
process mother {
L2: 剥一个桔子;
P(sp);
把桔子放入plate;
V(sg1);
goto L2;
}
process son {
L3: P(sg1);
从plate中取桔子;
V(sp);
吃桔子;
goto L3;
}
process daughter {
L4: P(sg2);
从plate中取苹果;
V(sp);
吃苹果;
goto L4;
}
int random;
Semaphore offer1 = offer2 = offer3 = ;
Semaphore finish = ;
process producer(){
while(){
random = 任意随机整数;
random = random % ;
P(finish);
对应两种材料放在桌子上;
if(random==) V(offer1);
else if(random==) V(offer2);
else V(offer3);
}
}
process consumer_1(){
while(){
P(offer1);
拿自己缺的那两种材料;
卷成烟抽掉;
V(finish);
}
}
- 哲学家就餐问题
Semaphore fork[];
for (int i = ; i < ; i++)
fork[i] = ;
cobegin
process philsopher_i() {
while (true) {
think();
P(fork[i]);
P(fork[(i+)%]);
eat();
V(fork[i]);
V(fork[(i+)%]);
}
}
coend
Semaphore fork[];
for (int i = ; i < ; i++)
fork[i] = ;
Semaphore mutex = ;
cobegin
process philsopher_i() {
while(true){
P(mutex);
P(fork[i]);
P(fork[(i+)%]);
V(mutex);
eat();
V(fork[i]);
V(fork[(i+)%]);
}
}
coend
- 写者问题
int readcount = ;
Semaphore writeblock = ;
Semaphore mutex = ;
cobegin
process read_i() {
P(mutex);
readcount++;
if(readcount==) P(writeblock); //自己是唯一的读进程,写者在写文件时自己不能开始读,自己开始读后不允许写操作
V(mutex);
/*读文件*/
P(mutex);
readcount-—;
if(readcount==) V(writeblock); //自己是唯一的读进程,读文件完成后允许写操作
V(mutex);
}
process write_j() {
P(writeblock);
/*写文件*/
V(writeblock);
}
coend
- 男女共浴问题、汽车过桥问题
Semaphore mutex;
Semaphore mutex_man = mutex_woman= ;
int mancount = womancount =;
Process man(){
P(mutex_man)
mancount++;
if(mancount==) P(mutex);
V(mutex_man);
洗澡;
P(mutex_man);
mancount—;
if(mancount==) V(mutex);
V(mutex_man)
}
- 理发师问题
int waiting = ;
Semaphore customers = ;
Semaphore barbers = ;
Semaphore mutex = ;
cobegin
process barbers() {
while(true) {
P(customers);//判断是否有顾客,没有的话理发师睡眠
P(mutex);
waiting--;
V(barbers);//理发师准备为顾客理发
V(mutex);
cuthair(); //理发师理发,不应放在临界区
}
}
process customer_i() {
P(mutex);
if(waiting<N) {
waiting++;
V(customers);//唤醒理发师
V(mutex);
P(barbers);//如果理发师忙则等待
get_haircut();
}
else V(mutex);//人满了,顾客离开
}
coend
操作系统-PV操作的原理和几种常见问题的更多相关文章
- 操作系统实验——PV操作实现生产者消费者模型
操作系统PV操作之--生产者消费者模型 个人博客主页 参考资料: Java实现PV操作 | 生产者与消费者 浙大公开课 在操作系统的多进程.多线程操作中经常会有因为同步.互斥等等问题引发出的一系列问题 ...
- 操作的系统的PV操作
转自:https://blog.csdn.net/sunlovefly2012/article/details/9396201 在操作系统中,进程之间经常会存在互斥(都需要共享独占性资源时) 和同步( ...
- Java实现PV操作 | 读者与写者(在三种情况下进行讨论)
注 :本文应结合[天勤笔记]进行学习. 1.读者优先 设置rmutex信号量来对readcount变量进行互斥访问.mutex信号量对写者与读者进行同步. static syn rmutex=new ...
- 信号量与PV操作
在计算机操作系统中,PV操作是进程管理中的难点.首先应弄清PV操作的含义:PV操作由P操作原语和V操作原语组成(原语是不可中断的过程),对信号量进行操作,具体定义如下: P(S):①将信号量S的 ...
- 软测试综述——PV操作
在操作系统中,进程之间常常会存在相互排斥(都须要共享独占性资源时)和同步(完毕异步的两个进程的协作)两种关系.而信号量和PV操作完美有效的处理了这两种情况. 相互排斥:就好比过独木桥,一 ...
- <<操作系统精髓与设计原理>>读书笔记(一) 并发性:互斥与同步(1)
<<操作系统精髓与设计原理>>读书笔记(一) 并发性:互斥与同步 并发问题是所有问题的基础,也是操作系统设计的基础.并发包括很多设计问题,其中有进程间通信,资源共享与竞争,多个 ...
- 转 信号量与PV操作
在计算机操作系统中,PV操作是进程管理中的难点.首先应弄清PV操作的含义:PV操作由P操作原语和V操作原语组成(原语是不可中断的过程),对信号量进行操作,具体定义如下: P(S):①将信号量S的 ...
- 【转】进程同步之信号量机制(pv操作)及三个经典同步问题
原文地址:http://blog.csdn.net/speedme/article/details/17597373 上篇博客中(进程同步之临界区域问题及Peterson算法),我们对临界区,临界资源 ...
- OS__信号量(semaphore)PV操作
信号量的概念 1.信号量的类型定义 信号量(semaphore)的数据结构为记录型数据结构一个值和一个指针,指针指向等待该信号量的下一个进程.信号量的值与相应资源的使用情况有关,在操作系统中,信号量用 ...
随机推荐
- C语言中的 “>>”与“<<”
1. ">>" int x = 16; printf("%d\n", x >> 1); 先将x转成二进制 10000, 不读最后一位, ...
- 360随身WiFi3:纯净版无线网卡驱动下载及安装教程(Windows10版本)
对于不带无线网卡的台式机,买一个360随身WiFi当无线网卡是很省钱的方法.但是这个随身WiFi3用的芯片较为奇葩,Win10下不太好找驱动.什么,你问我为啥不用360官网上的驱动?那个“驱动”装了之 ...
- 企业权限管理(SSM整合)(总结)
学于黑马程序员和传智播客联合做的教学项目 感谢 黑马程序员官网 传智播客官网 个人根据教程的每天的工作进度的代码和资料 密码:cti5 b站在线视频 微信搜索"艺术行者",关注并回 ...
- 爬虫管理平台以及wordpress本地搭建
爬虫管理平台以及wordpress本地搭建 学习目标: 各爬虫管理平台了解 scrapydweb gerapy crawlab 各爬虫管理平台的本地搭建 Windows下的wordpress搭建 爬虫 ...
- 从RNN到BERT
一.文本特征编码 1. 标量编码 美国:1 中国:2 印度:3 … 朝鲜:197 标量编码问题:美国 + 中国 = 3 = 印度 2. One-hot编码 美国:[1,0,0,0,…,0]中国:[0, ...
- asp.net mvc 模拟百度搜索
页面代码: <td><span>*</span>车牌号码:</td> <td> <div id="search"& ...
- luogu P4726 【模板】多项式指数函数 多项式 exp 牛顿迭代 泰勒展开
LINK:多项式 exp 做多项式的题 简直在嗑药. 前置只是 泰勒展开 这个东西用于 对于一个函数f(x) 我们不好得到 其在x处的取值. 所以另外设一个函数g(x) 来在x点处无限逼近f(x). ...
- 牛客练习赛60 E 旗鼓相当的对手
LINK:旗鼓相当的对手 考场上遇到这种简单的树形dp优化题目我真的不一定能写出来.. 虽然这道题思路很简单 设f[i][j]表示距i距离为j的点的个数 g[i][j]表示距i距离为j的点权和. 可以 ...
- tracebace用法
介绍一下traceback 平时看到的程序的错误信息也就是traceback信息 举个简单例子: import traceback try: s = [1, 2, 3] print s[5] exce ...
- DataGrip,一款数据库客户端工具,IDEA的兄弟是真香!
DataGrip 是一款数据库管理客户端工具,方便的连接到数据库服务器,执行sql语句.创建表.创建索引以及导出数据等. DataGrip 支持几乎所有主流的关系数据库产品,如 DB2.Derby.H ...