Day56-59 进程的状态、进程控制、进程通信方式

我是大白(●—●),这是我开始学习记录大白Java软件攻城狮晋升之路的第五十六到五十九天,今天学习的是进程的状态、进程控制、进程的通信方式,明天过生日,周末鸽了两天没学习,O(∩_∩)O哈哈~ ,明天可能又要鸽了~

文章目录

  • 一、进程的状态
    • 1.进程的三种基本状态
    • 2.另外的两种状态
    • 3.五种进程的状态
  • 二、进程的转换
  • 三、进程控制
    • 1.什么是进程控制?
    • 2.如何实现进程控制
    • 3.进程控制相关的原语
  • 四、进程通信
    • 1.什么是进程通信
    • 2.进程通信——共享存储
    • 3.进程通信——管道通信
    • 4.进程通信——消息传递

一、进程的状态

进程是程序的一次执行。在这个执行过程中,有时进程正在被CPU处理,有时又需要等待CPU服务,可见,进程的状态是会有各种变化。为了方便对各个进程的管理,操作系统需要将进程合理地划分为几种状态。

1.进程的三种基本状态

image.png

2.另外的两种状态

image.png
image.png
image.png

3.五种进程的状态

Day56-59 进程的状态、进程控制、进程通信方式_第1张图片

二、进程的转换

经过上文对进程的状态介绍,那就会有一个问题,什么时候或者情况下需要转换进程状态呢?

image.png注意:不能由阻塞态直接转换为运行态,也不能由就绪态直接转换为阻塞态(因为进入阻塞态是进程主动请求的,必然需要进程在运行时才能发出这种请求)

三、进程控制

1.什么是进程控制?

进程控制的主要功能是对系统中的所有进程实施有效的管理,它具有创建新进程、撤销已有进程、实现进程状态转换等功能。
简化理解:反正进程控制就是要实现进程状态转换
image.png

2.如何实现进程控制

还记得之前提到过的进程组织的问题么?
image.png
image.png
用原语实现进程控制。原语的特点是执行期间不允许中断,只能一气呵成。这种不可被中断的操作即原子操作。
原语采用“关中断指令”和“开中断指令”实现
image.png
显然,开/关中断指令的权限非常大,必然是只允许在核心态下执行的特权命令

3.进程控制相关的原语

image.png
image.png
image.png
image.png
image.png

四、进程通信

1.什么是进程通信

顾名思义,进程通信就是指进程之间的信息交换。
进程是分配系统资源的单位(包括内存地址空间),因此各进程拥有的内存地址空间相互独立。
Day56-59 进程的状态、进程控制、进程通信方式_第2张图片
为了保证安全,一个进程不能直接访问另一个进程的地址空间
但是进程之间的信息交换又是必须实现的。为了保证进程间的安全通信,操作系统提供了一些方法。
Day56-59 进程的状态、进程控制、进程通信方式_第3张图片

2.进程通信——共享存储

image.png

3.进程通信——管道通信

image.png

  1. 管道只能采用半双工通信,某一时间段内只能买现单向的传输。如果要实现双向同时通信,则需要设置两个管道
  2. 各进程要互斥地访问管道。
  3. 数据以字符流的形式写入管道,当管道写满时,写进程的write()系统调用将被阻塞,等待读进程将数据取走。当读进程将数据全部取走后,管道变空,此时读进程的read()系统调用将被阻塞
  4. 如果没写满,就不允许读。如果没读空,就不允许写。
  5. 数据一旦被读出,就从管道中被抛弃,这就意味着读进程最多只能有一个,否则可能会有读错数据的情况。

4.进程通信——消息传递

进程间的数据交换以格式化的消息(Message)为单位。进程通过操作系统提供的“发送消息/接收消息”两个原语进行数据交换。
image.png

你可能感兴趣的:(408,java,进程,操作系统,1024程序员节)