进程控制理论知识

程序静态的存储在计算机上,用适当形式描述的算法。。
进程一个具有一定独立功能的程序的一次运行的活动;是正在运行程序的一个抽象。

进程的三个状态:
1、运行态(该时刻进程实际占用CPU)
2、就绪态(可运行,但因为其他进程正在运行而暂时停止)
3、阻塞态(除非某种外部事件发生,否则进程不能运行)
前两种逻辑上是相似的,两种进程都可以运行,,只是因为进程调度原因。。第3种是因为自身固有原因而挂起。。
                            
                                三种状态的切换示意图



进程ID:标示进程的唯一数字
父进程:PPID
启动进程的用户ID: UID


临界资源:操作系统中将同一时刻只允许一个进程访问的资源;譬如共享内存,共享文件,共享变量,,各种共享的资源。

临界区:进程中访问临界资源的那段代码称为临界区。为实现对临界资源的互斥访问,应保证各进程互斥地进入各自的临界区
           使用临界区互斥的示意图(B等到A离开临界区才进入

竞争条件:当两个或者多个进程读写某些共享数据时,最后的结果取决于进程运行的精确时序。。。
采用互斥的方法避免竞争条件,即以某种手段确保当一个进程在使用一个共享变量或者文件时,其他的进程不能做同样的操作。
解决竞争条件问题时满足的4个条件
1、任何两个进程不能同时处于临界区
2、不应对CPU的速度和数量做任何假设
3、临界区外运行的进程不得阻塞其他进程
4、不得使进程无限期等待进入临界区
       
进程调度:按照一定的算法,从一组待运行的进程中选出一个来占用CPU运行。
调度算法的分类:(因为不同的系统中,调度程序的优化效果是不一样的,根据环境的不同分类)
1、批处理
一些商业领域的应用,一些周期性作业(账目支出、账目收入),每个进程都有较长时间的抢占式算法,,减少了进程之间的切换从而提高CPU性能
2、交互式
譬如服务器,避免一个进程长期霸占CPU而拒绝为其他进程提过服务
3、实时
通常的调度算法
1、先来先服务
2、短进程优先调度
3、高优先级优先调度
4、时间片轮转法

调度的时机:
1、非抢占式调度
挑选一个进程,让该进程运行直至被阻塞或者该进程自动释放CPU。。
2、抢占式调度
挑选出一个进程,并让该进程只能运行一个固定的时间段,,超过这个时段,进程还在运行的话就会被挂起。。进行抢占式调度处理时,需要在时间间隔的末端发生时钟中断,以便把CPU控制返回调度程序。如果没有可用时钟,那么只能用非抢占式调度了



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Unix网络编程卷2:进程间通信PDF是一本非常有用的书籍,它涵盖了关于进程间通信的所有关键知识。 进程间通信是指进程之间交换数据或信息的过程,这对于理解操作系统以及网络编程非常重要。本书不仅讲解了进程通信的基础知识,还深入解释了信号、管道、消息队列、共享内存等高级通信方法。 在本书中,作者详细介绍了如何使用各种系统调用和库函数实现不同类型的进程间通信。读者将学习如何在不同进程之间共享文件句柄,如何创建匿名和命名管道,以及如何使用信号和信号处理程序等。 此外,本书还说明了如何以面向对象的方式编写并发程序。作者展示了C++ STL标准库和Boost库的使用方法,这些工具可以帮助程序员编写更高效的并发程序。 总之,Unix网络编程卷2:进程间通信PDF是一本非常有用的书籍,可以通过实例和详细解释帮助读者更好地理解进程通信的概念和技术。 ### 回答2: 《Unix网络编程 卷2:进程间通信》是一本经典的计算机网络编程书籍,主要讲解了在UNIX环境下进程之间如何进行通信,并介绍了常用的进程间通信机制和技术。 该书包含了进程间通信的基本概念和理论知识,从分析进程地址空间、进程控制、信号处理、进程间通信等多个方面详细阐述了进程间通信的各种实现方式,并通过实际的例子和代码提供了丰富的实践经验。同时,该书还包含了大量的参考文献和附录,方便读者深入学习和进一步研究进程间通信技术。 该书涵盖的主要内容包括UNIX进程模型、基本进程管理、进程资源和限制、信号、管道、消息队列、共享内存、信号量、套接字、RPC、XSI IPC等多个进程间通信机制和技术。其中,对于常用的进程间通信方式如管道、消息队列、共享内存、信号量等都进行了详细的介绍。同时,该书还介绍了进程间通信的高级技术,如分布式进程间通信(RPC)和XSI IPC等,帮助读者更好地实现进程间的通信。 总之,《Unix网络编程 卷2:进程间通信》是一本非常重要的计算机网络编程参考书籍,对于了解UNIX进程模型、深入理解进程间通信技术以及开发UNIX网络应用程序有很大的帮助。该书不仅适合计算机专业的学生和研究人员,也适合从事UNIX网络编程工作的程序员和工程师阅读。 ### 回答3: 《UNIX网络编程 卷2:进程间通信》是由W.Richard Stevens和Stephen A. Rago合作编写的,是一本关于UNIX如何实现进程间通信的技术指南,是一本精华之作。该书的主要内容包括:管道、FIFO、消息队列、信号量、共享内存以及套接字等多种进程间通信方式。同时,书中也介绍了如何在不同的进程间进行信息交换、如何保证进程的同步性和互斥性以及如何利用各种进程间通信工具实现并发编程。 该书在介绍管道、FIFO、消息队列等进程间通信机制时,都给出了详细的代码实现,并给出了该技术的优缺点以及适用场景。同时,书中还提供了丰富的案例分析,让读者能通过实践更好地理解和掌握这些技术。此外,书中还介绍了一些进程线程相关的基础知识,如进程的创建、精灵进程线程的创建、线程的同步等,这些知识为读者更好地理解进程间通信技术提供了背景和基础。 总的来说,该书是一本深入浅出、全面系统的进程间通信技术指南,它通过具体的代码实现和案例分析,使得读者能在实践中更好地理解和掌握这些技术,并能够开发出高效可靠的应用程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值