信号量的应用

信号量


1、信号量和P、V原语

信号量和P、V原语由迪杰斯特拉提出

互斥:P、V在同一个进程中
同步:P、V在不同进程中

信号量值含义:
(1)S>0: S表示可用资源的个数。
(2)S=0:表示无可用资源,无等待进程。
(3)S<0: |S|表示等待队列中进程个数。

P原语:

P(s)
{
    s.value = s.value--;
    if(s.value < 0)
    {
       //该进程状态置为等待状态
       //将该进程的PCB插入相应的等待队列s.queue末尾
    }
}

V原语:

V(s)
{
    s.value = s.value++;
    if(s.value <= 0)
    {
       //唤醒相应等待队列s.queue中等待的一个进程
       //改变其状态为就绪态,并将其插入就绪队列
    }
}

2、信号量集函数

//(1)semget函数
//   功能:用来创建和访问一个信号量集
//原型:
    int semget(key_t key,int nsems,int semflg);
//参数:  key:信号集的名字
//       nsems:信号集中信号量的个数
//       semflg:由九个权限标志构成,它们的用法和创建文件时使用的mode模式标志是一样的
//返回值:成功返回0,失败返回-1


//(2)shmctl函数
//    功能:用于控制信号量集
//原型:
    int semctl(int semid,int semnum,int cmd, ...);
//参数:  semid:由semget返回的信号集标识码
//       semnum:信号集中信号量的个数
//       cmd:将要采取的动作(有三个可取值)
//       最后一个参数根据不同而不同
//返回值:成功返回0,失败返回-1


//(3)semop函数
//功能:用来创建和访问一个信号量集
//原型:
    int semop(int semid,struct sembuf* sops,unsigned nsops);
//参数:
//  semid:是该信号
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值