我是大白(●—●),这是我开始学习记录大白Java软件攻城狮晋升之路的第五十六到五十九天,今天学习的是进程的状态、进程控制、进程的通信方式,明天过生日,周末鸽了两天没学习,O(∩_∩)O哈哈~ ,明天可能又要鸽了~
文章目录
一、进程的状态
进程是程序的一次执行。在这个执行过程中,有时进程正在被CPU处理,有时又需要等待CPU服务,可见,进程的状态是会有各种变化。为了方便对各个进程的管理,操作系统需要将进程合理地划分为几种状态。
1.进程的三种基本状态
2.另外的两种状态
3.五种进程的状态
二、进程的转换
经过上文对进程的状态介绍,那就会有一个问题,什么时候或者情况下需要转换进程状态呢?
注意:不能由阻塞态直接转换为运行态,也不能由就绪态直接转换为阻塞态(因为进入阻塞态是进程主动请求的,必然需要进程在运行时才能发出这种请求)
三、进程控制
1.什么是进程控制?
进程控制的主要功能是对系统中的所有进程实施有效的管理,它具有创建新进程、撤销已有进程、实现进程状态转换等功能。
简化理解:反正进程控制就是要实现进程状态转换
2.如何实现进程控制
还记得之前提到过的进程组织的问题么?
用原语实现进程控制。原语的特点是执行期间不允许中断,只能一气呵成。这种不可被中断的操作即原子操作。
原语采用“关中断指令”和“开中断指令”实现
显然,开/关中断指令的权限非常大,必然是只允许在核心态下执行的特权命令
3.进程控制相关的原语
四、进程通信
1.什么是进程通信
顾名思义,进程通信就是指进程之间的信息交换。
进程是分配系统资源的单位(包括内存地址空间),因此各进程拥有的内存地址空间相互独立。
为了保证安全,一个进程不能直接访问另一个进程的地址空间。
但是进程之间的信息交换又是必须实现的。为了保证进程间的安全通信,操作系统提供了一些方法。
2.进程通信——共享存储
3.进程通信——管道通信
- 管道只能采用半双工通信,某一时间段内只能买现单向的传输。如果要实现双向同时通信,则需要设置两个管道。
- 各进程要互斥地访问管道。
- 数据以字符流的形式写入管道,当管道写满时,写进程的write()系统调用将被阻塞,等待读进程将数据取走。当读进程将数据全部取走后,管道变空,此时读进程的read()系统调用将被阻塞。
- 如果没写满,就不允许读。如果没读空,就不允许写。
- 数据一旦被读出,就从管道中被抛弃,这就意味着读进程最多只能有一个,否则可能会有读错数据的情况。
4.进程通信——消息传递
进程间的数据交换以格式化的消息(Message)为单位。进程通过操作系统提供的“发送消息/接收消息”两个原语进行数据交换。