热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

进程调度&调度算法

##初识调度在学校时,只要讲到操作系统时我就见到周公了。所以我非常不喜欢所谓的模型,对计算机的理解也习惯从生活中来到生活中去,现在对于原理有了一些浅显的理解,那么我就抛砖引玉,希望

初识调度

在学校时,只要讲到操作系统时我就见到周公了。所以我非常不喜欢所谓的模型,对计算机的理解也习惯从生活中来到生活中去,现在对于原理有了一些浅显的理解,那么我就抛砖引玉,希望得到大佬的指正。
在了解进程调度时,先了解两个小故事


齐国使者到大梁来,孙膑以刑徒的身份秘密拜见,劝说齐国使者。齐国使者觉得此人是个奇人,就偷偷地把他载回齐国。齐国将军田忌非常赏识他,并且待如上宾。田忌经常与齐国众公子赛马,设重金赌注。孙膑发现他们的马脚力都差不多,马分为上、中、下三等,于是对田忌说:“您只管下大赌注,我能让您取胜。”田忌相信并答应了他,与齐王和各位公子用千金来赌注。比赛即将开始,孙膑说:“现在用您的下等马对付他们的上等马,用您的上等马对付他们的中等马,用您的中等马对付他们的下等马。”三场比赛结束后,田忌一场败而两场胜,最终赢得齐王的千金赌注。因此田忌把孙膑推荐给齐威王。齐威王向他请教了兵法,封他为军师。 ————《史记》卷六十五:《孙子吴起列传第五》


第二个小故事离我们没有那么遥远,就是时间行者,空间刺客罗某,具体事情可以百度
技术图片

计算机的进程调度,实际上没有那么复杂(咱得战略上藐视它),简单的讲就是通过调整运行程序来实现操作系统的最优化。


程序执行的模式

一般而言,同一时间CPU只有一个只能执行一个程序(多进程并发暂不讨论)。
现行条件下,程序的执行大概有两种



  • CPU导向/计算密集型程序
    CPU导向(bound)也叫计算密集型,它系统的硬盘、内存性能相对CPU要好很多,此时,系统运作大部分的状况是CPU Loading 100%,CPU要读/写I/O(硬盘/内存),I/O在很短的时间就可以完成,而CPU还有许多运算要处理,CPU Loading很高。
    在多重程序系统中,大部份时间用来做计算、逻辑判断等CPU动作的程序称之CPU bound。例如一个计算圆周率至小数点一千位以下的程序,在执行的过程当中绝大部份时间用在三角函数和开根号的计算,便是属于CPU bound的程序。
    CPU bound的程序一般而言CPU占用率相当高。这是因为任务本身不太需要访问I/O设备,当然也可能是因为程序是多线程实现因此屏蔽掉了等待I/O的时间。
    就像去高档餐厅吃饭,只要有人来吃,几乎不用排队,但是也要过段时间才能吃饭,毕竟它做菜的时间长
    技术图片



  • I/O导向/交互密集型程序
    IO密集型指的系统CPU性能相对硬盘、内存要好很多,此时,系统运作,大部分的状况是CPU在等I/O (硬盘/内存) 的读/写操作,此时CPU负载并不高。
    I/O bound的程序一般在达到性能极限时,CPU占用率仍然较低。这可能是因为任务本身需要大量I/O操作,而调度做得不是很好,没有充分利用处理器能力。
    这种程序大部分的时间用在I/O,I/O后在CPU上进行短暂的CPU运算,然后进行下一次的I/O,这样循环往复...游戏就是一种I/O导向程序,在我们按下qwer后,cpu进行短暂的运算,就又等着下一次I/O
    而十一黄金周到某著名小吃店则不一样,虽然到吃上也要花很久,它菜做的很快,只不过大部分的时间都用在排队上
    技术图片




先来先服务调度算法FCFS(First Come First Serve)

字面意思,先来后到。这个算法也不知道是谁想出来的,或许就是计算机界约定俗成的吧。
这种算法,看似公允,实则非常反人类。例如:在政务大厅排队处理违章,你只需要三分钟,签个字就行;但是排你前面的人却要搞两钟头,这样实际上你需要的时间就是两钟头零三分钟......


时间片轮转调度算法RR(Round-Robin)

时间片轮转其实就是对FCFS的一种优化,目的就是为了改善短程序排在长程序后面也能快速执行,其方法是在一定的时间内(时间片)将进程轮换。
例如:
现在有两个程序



















程序执行时间
A100s
B1s

如果用FCFS方法先来后到,A要100秒,B就得耗时101秒。两个程序平均耗时100.5秒
用RR的方法,假设每一秒轮换一次。A先来执行一秒,然后轮换给B执行一秒,B就执行完了,A接着执行第99秒。这样实际上A就要花101秒,B花2秒(A执行第一秒时B在等待)。两个程序平均花51.5秒。
每10秒轮换一次,平均时间为65秒(A10s+B等A10s+B10s+A等B10s+A90s)其中B实际上在第二波的时间片里的第一秒就完成了,但是余下的九秒也得算在里面,A也得完完整整的等待10秒;
每20秒轮换一次,平均时间为80秒
每30秒轮换一次,平均时间为95秒
每50秒轮转一次,平均时间为125秒
显然如果时间片选择的过大,RR就会完全退化成为FCFS,甚至还不如FCFS。请注意当时间片为三十秒时虽然平均用时还是比FCFS的100.5小,但是CPU在同一时刻只能做一件事,那么切换时间片本身就要耗费时间所以,我们上面的算法其实是不严谨的的。应该是:
51.5+两次切换时间片的时间;65+两次切换时间片的时间........
但是时间片选择的过小,切换时间片的次数太多本身就会成为cpu的负担,而且切换时间片本身也要时间.....


优先级调度算法


特殊优先级“短任务调度算法”SJF(shortest job first)

SJF算法以进程的运行时间长度作为优先级,进程运行时间越短,优先级越高。也就是谁运行的最快谁先上,运行的慢就不要占前排。
是不是有一点像上学时,谁成绩好谁就坐前排,成绩差就不要占着前面的位置,所以嘛!现行计算机就是一种伪科学,来源于生活,是一种人造技术。

SJF算法的缺点
必须预知进程的运行时间。即使是程序员也很难准确估计进程运行时间。如果估计过低,系统就可能按估计的时间终止进程的运行,但此时进程并未完成,故一般都会偏长估计
对长进程不利。长进程的周转时间会明显地增长。可怕的是,SJF算法完全忽视进程等待时间,可能使进程等待时间过长,出现饥饿现象。
人机无法实现交互。
完全未考虑进程的紧迫程度。不能保证紧迫性进程得到及时处理。
(未完待续)


混合调度算法


保证调度算法


彩票调度算法


用户公平调度算法

进程调度&调度算法



推荐阅读
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
author-avatar
h53695088
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有