实时 *** 作系统和非实时 *** 作系统的区别

实时 *** 作系统和非实时 *** 作系统的区别,第1张

  实时 *** 作系统概述

  实时 *** 作系统(RTOS)是指当外界事件或数据产生时,能够接受并以足够快的速度予以处理,其处理的结果又能在规定的时间之内来控制生产过程或对处理系统做出快速响应,调度一切可利用的资源完成实时任务,并控制所有实时任务协调一致运行的 *** 作系统。提供及时响应和高可靠性是其主要特点。

  实时 *** 作系统是抢占式 *** 作系统,如果你的进程优先级高,则肯定第一个得到执行,直至结束执行,中间的时间通过CPU频率等可以推算出来。

  其实就是要求你对他的请求,他得在一定时限内给你结果,而不能因为系统忙或调度算法的原因拖沓,也就是只要指定了时间或发生了高优先级时间,无论任何 *** 作,必须立刻中断,即使内核也是如此。

  Windows的内核是不可抢占的,所以它不是实时 *** 作系统。Linux是软实时的,内核中仍然有大量不可抢占区域。时限要求高的是硬实时,时限要求低的是软实时

  非实时 *** 作系统概述

  通常的通用 *** 作系统Windows和Linux都叫分时 *** 作系统,一般采用公平调度算法,线程/进程一多就得分享CPU时间,Linux下有针对“实时进程”的调度,调度算法和普通进程不一样,但也只是相对的响应时间降低而已,类似的Windows下的“实时”优先级,也只不过是最高优先级,而不是真正的实时

  真正的实时 *** 作系统内核是可中断可抢占的。而非实时的 *** 作系统通常在执行内核功能时是不可中断的,Linux是软实时的,它在内核中加入了若干可中断点,而不是任何时候都允许中断。

  Windows的内核是不可抢占的,所以它不是实时 *** 作系统。Linux是软实时的,内核中仍然有大量不可抢占区域。

  这样对内核的设计就要求很高。

  实时 *** 作系统和非实时 *** 作系统的区别

  实时系统与非实时系统的根本区别在于:实时系统具有与外部环境及时交互作用的能力。也就是说实时系统从外部获取信息以及系统得出结论要在很短的限制时间内完成。

  嵌入式实时系统中采用的 *** 作系统我们称为嵌入式实时 *** 作系统,它既是嵌入式 *** 作系统,又是实时 *** 作系统。作为一种嵌入式 *** 作系统,它具有嵌入式软件共有的可裁剪、低资源占用、低功耗等特点;而作为一种实时 *** 作系统(本文对实时 *** 作系统特性的讨论仅限于强实时 *** 作系统,下面提到的实时 *** 作系统也均指强实时 *** 作系统),它与通用 *** 作系统(如Windows、Unix、Linux等)相比有很大的差别,下面我们将通过比较这两种 *** 作系统之间的差别来逐步描述实时 *** 作系统的主要特点。

  我们在日常工作学习环境中接触最多的是通用 *** 作系统,通用 *** 作系统是由分时 *** 作系统发展而来,大部分都支持多用户和多进程,负责管理众多的进程并为它们分配系统资源。分时 *** 作系统的基本设计原则是:尽量缩短系统的平均响应时间并提高系统的吞吐率,在单位时间内为尽可能多的用户请求提供服务。由此可以看出,分时 *** 作系统注重平均表现性能,不注重个体表现性能。如对于整个系统来说,注重所有任务的平均响应时间而不关心单个任务的响应时间,对于某个单个任务来说,注重每次执行的平均响应时间而不关心某次特定执行的响应时间。通用 *** 作系统中采用的很多策略和技巧都体现出了这种设计原则,如虚存管理机制中由于采用了LRU等页替换算法,使得大部分的访存需求能够快速地通过物理内存完成,只有很小一部分的访存需求需要通过调页完成,但从总体上来看,平均访存时间与不采用虚存技术相比没有很大的提高,同时又获得了虚空间可以远大于物理内存容量等好处,因此虚存技术在通用 *** 作系统中得到了十分广泛的应用。类似的例子还有很多,如Unix文件系统中文件存放位置的间接索引查询机制等,甚至硬件设计中的Cache技术以及CPU的动态分支预测技术等也都体现出了这种设计原则。由此可见,这种注重平均表现,即统计型表现特性的设计原则的影响是十分深远的。

  而对于实时 *** 作系统,前面我们已经提到,它除了要满足应用的功能需求以外,更重要的是还要满足应用提出的实时性要求,而组成一个应用的众多实时任务对于实时性的要求是各不相同的,此外实时任务之间可能还会有一些复杂的关联和同步关系,如执行顺序限制、共享资源的互斥访问要求等,这就为系统实时性的保证带来了很大的困难。

  因此,实时 *** 作系统所遵循的最重要的设计原则是:采用各种算法和策略,始终保证系统行为的可预测性(predictability)。可预测性是指在系统运行的任何时刻,在任何情况下,实时 *** 作系统的资源调配策略都能为争夺资源(包括CPU、内存、网络带宽等)的多个实时任务合理地分配资源,使每个实时任务的实时性要求都能得到满足。与通用 *** 作系统不同,实时 *** 作系统注重的不是系统的平均表现,而是要求每个实时任务在最坏情况下都要满足其实时性要求,也就是说,实时 *** 作系统注重的是个体表现,更准确地讲是个体最坏情况表现。举例来说,如果实时 *** 作系统采用标准的虚存技术,则一个实时任务执行的最坏情况是每次访存都需要调页,如此累计起来的该任务在最坏情况下的运行时间是不可预测的,因此该任务的实时性无法得到保证。从而可以看出在通用 *** 作系统中广泛采用的虚存技术在实时 *** 作系统中不宜直接采用。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/2484492.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-04
下一篇 2022-08-04

发表评论

登录后才能评论

评论列表(0条)

保存