计算机操作系统学习之信号量机制

一.信号量

  • 信号量其实就是一个变量,可以用信号量来表示系统中某种资源的数量
  • 用户进程可以使用操作系统提供的一对原语来操作信号量
  • 一对原语:wait(S)和signal(S)
    可以理解为wait和signal是函数名,信号量S是传入的参数
  • wait和signal通常又称为P、V操作

二.整型信号量

概念:用一个整数型变量作为信号量,数值表示某种资源数
与普通整型变量的区别:对信号量只能进行初始化、P、V三种操作
举例

在这里插入图片描述

  • 初始化S=1,表示当前系统只有只有一个打印机资源可用
  • 执行P操作(wait原语):相当于进入区。当发现S<=0,则说明资源数不够,那么则一直循环等待。如果发现S>0,则说明资源足够,则执行S-1,说明该进程占用了一个资源。这个过程其实也就是检查和上锁
  • 执行V操作(signal原语):相当于退出区。就是使用完资源以后,在退出区执行S+1,就是释放资源

存在的问题:不满足让权等待原则,会发生忙等

三.记录型信号量

为了解决整型信号量的会发生忙等的问题,提出了记录型信号量

1.记录型信号量的定义

在这里插入图片描述

  • 记录型信号量中包含两部分,value表示剩余的资源数,L表示信号量S的等待队列(即就绪队列)。

2.P操作

在这里插入图片描述

  • 当有进程要使用资源时,使用wait原语申请资源
  • 先让资源数value-1,然后判断此时的value值是否小于0,如果>=0说明还有剩余资源,那么就给进程分配资源
  • 如果value值小于0,则说明已经没有剩余资源了,因此就要执行原语block(S.L):使该进程从运行态进入就绪态,并挂入信号量S的等待队列中。
  • 可见该机制遵循了让权等待原则,不会出现忙等现象

3.V操作

在这里插入图片描述

  • 进程使用完资源后,通过signal原语释放资源
  • 首先让value值加1,代表释放一个资源,然后判断value值是否<=0,如果大于0,则说明此时没有进程在S的等待队列中
  • 如果value值<=0,则说明此时S的等待队列中有进程在等待该资源,那么就要执行原语wakeup(S.L):即从等待队列中唤醒一个进程,让其从就绪态变成运行态,
  • 4
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java进程管理系统是一个用于管理操作系统中的进程的软件程序。它提供了一组功能来创建、终止、调度和监视进程。 首先,Java进程管理系统可以创建新的进程。它允许用户使用一些指定的参数和设定来启动新的进程。这些参数可能包括进程的优先级、内存分配、代码路径等。通过Java进程管理系统,用户可以方便地创建并管理多个进程。 其次,Java进程管理系统可以终止进程。在某些情况下,用户可能需要中止正在运行的进程,例如当进程出现错误或者需要释放系统资源时。Java进程管理系统允许用户通过指定进程的标识符或其他特定信息,来终止指定进程。 此外,Java进程管理系统还提供了进程调度功能。它可以基于一些调度算法,如先来先服务(FCFS)、时间片轮转等,来决定进程的执行顺序。用户可以通过Java进程管理系统设置进程的优先级,从而影响进程的调度顺序。 最后,Java进程管理系统可以监视进程的运行状态。它可以提供进程的一些重要信息,如进程的ID、执行状态等。通过Java进程管理系统,用户可以实时监视进程,并及时获得相关信息。 总结而言,Java进程管理系统是一个用于管理操作系统中进程的软件程序。它提供了创建、终止、调度和监视进程的功能。通过Java进程管理系统,用户可以方便地控制和管理进程,并有效地利用系统资源。这种管理系统可以在各种操作系统上运行,并且具有良好的扩展性和灵活性。 ### 回答2: Java进程管理系统是一种基于Java编程语言开发的操作系统实验,用于管理和控制计算机上的进程。该系统主要包含进程创建、进程调度、进程同步和进程通信等功能。 首先,进程创建是指在系统中生成新的进程。Java进程管理系统可以通过调用Java的进程相关类和方法来创建进程,例如使用ProcessBuilder类来创建新的进程对象,并通过该对象执行指定的进程命令。 其次,进程调度是指根据一定的策略和算法,决定哪些进程可以获得执行时间。在Java进程管理系统中,可以通过使用多线程技术来实现进程调度。通过创建不同的线程对象,并分配不同的优先级给每个线程,可以实现简单的进程调度功能。 进程同步是指保证进程按照一定的顺序执行,避免出现竞争条件和进程间的冲突。Java进程管理系统可以使用锁、信号量等同步机制来实现进程同步。通过加锁和解锁等操作,可以控制进程对共享资源的访问,避免数据的不一致性和错误。 最后,进程通信是指进程之间通过一定的方式和机制进行信息交换和共享。Java进程管理系统可以使用Java的线程间通信机制,如共享内存、消息队列、信号量等来实现进程之间的通信。通过共享内存可以实现进程间的数据共享,通过消息队列可以实现进程间的异步通信,通过信号量可以实现进程间的同步通信。 总之,Java进程管理系统可以通过Java编程语言实现进程的创建、调度、同步和通信等功能。它为我们提供了一个实验平台,使我们能够了解和学习操作系统中进程管理的基本原理和机制

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值