首页IT科技使用的时候需要(【经验分享】使用了6年的实时操作系统,是时候梳理一下它的知识点了 | 文末赠书4本)

使用的时候需要(【经验分享】使用了6年的实时操作系统,是时候梳理一下它的知识点了 | 文末赠书4本)

时间2025-09-19 10:30:30分类IT科技浏览5029
导读:使用了6年的实时操作系统,是时候梳理一下它的知识点了...

使用了6年的实时操作系统                ,是时候梳理一下它的知识点了

摘要:

本文简单介绍了博主学习操作系统的心路历程                          ,同时还给大家总结了一下当下流行的几种实时操作系统        ,以及在工程中OSAL应该如何设计                  。希望对大家有所启发和帮助                        。

1 写在前面

操作系统一直伴随着我的工作            ,早些年我刚出来的工作的时候                          ,那时候用的是芯片平台是 飞思卡尔的MC9S12DG128             ,然后跑的是uCOS-II 的实时操作系统        。

由于在大学期间没有上过操作系统相关的专业课程        ,说来也惭愧                         ,在学校都是51单片机编程                  ,顶多用了一下AVR单片机(16位)    ,那时候想用STM32之类的高级单片机简直就是一种奢侈              。印象很深刻的是                        ,大三的时候出去实习                      ,公司那边用的还都是8位单片机那种,主要是产品逻辑简单                、硬件成本要求低                         。

受困于单片机平台的低端                    ,自然没有想过要给它上操作系统                          ,直到大四毕业找工作的时候    ,才发现原来自己学校做的那些课程实验                          、那些所谓的“业余比赛                  ”                ,压根不够看                          ,面试官直接忽略不计            。

就这么大四第一学期的9月10月基本就是在这样的面试鄙视的尴尬场面中度过        ,也正是那个时候            ,我觉得我TM是不是应该整点操作系统这种高卡东西                          ,不然面试老是面不上啊!

经过一番打听             ,得知嵌入式Linux操作系统在我们这一行还是很吃香的        ,于是我第一时间在学校的BBS上(对                         ,当时学校的BBS还是有点流行)发了一个帖子                  ,说征集学一起学习嵌入式Linux的童鞋    ,可以现学现卖                        ,参加当年的挑战杯项目         。

由于在学校也没啥影响力                      ,这个帖子很快就沉下去了,连个泡泡都没有                    ,自然也没找到合适的人一起学习嵌入式Linux                          。

苦于无奈执行                          ,我只能寄希望于我的毕设    ,由于学院几个毕设的指导老师都没有嵌入式Linux相关的课题                ,于是我厚着脸皮去找我们的系主任                          ,说我们想搞一个嵌入式Linux相关的毕业题目        ,能不能请老师通融下            ,给我们一次自拟定毕业题目的机会                。好在系主任爽快地答应了                          ,只是说选好了课题就要真真正正地去学             ,还是糊弄我们混个毕设    。

这段对话其实还是蛮打动我的        ,自然我也没有辜负他的期望                         ,还是把嵌入式Linux相关的基础知识学习了一遍                          。可能是幸运的降临                  ,就在第一学期的12月份    ,我有幸收到了第一份OFFER                        ,来自一个电力软件行业的大厂                      ,给出的薪资在当时同行来说还是比较高的                    。当然对比现在看到的动则年薪20W-30W起,我那比不上了                    ,但总算是上岸了。

我还是很感谢那段时间努力学习的自己                          ,到底还是现学现卖的操作系统知识帮了我一把    ,让我也成为同届同学中                ,令人羡慕的那一批人                      。

对了                          ,如果我没记错的话        ,当时我的毕设题目大概应该是:《基于S3C2410的MP3播放器》            ,当时是在ARM9上面跑的嵌入式Linux操作系统                        。

2 操作系统的定义

上面回忆当初在毕业前夕学习操作系统的一些故事                          ,下面这一章节给大家稍微总结一些操作系统的基本定义和概念    。

2.1 什么是操作系统?

操作系统(Operation System, OS) 是指控制和管理整个计算机系统的硬件和软件资源             ,并合理的组织和调度计算机的工作和资源的分配        ,以提供给用户和其它软件方便的接口和环境                         ,它是计算机系统中最基本的系统软件                  。

它的计算机体系中的位置如下面这种图所示:

从上图可以看出                  ,层次越往下    ,就越靠近硬件                        ,而操作系统正是在应用软件与计算机硬件之间的一个重要桥梁                      ,也正是因为有了操作系统这一层次的存在,才有了上层各式各样的应用软件                    ,也直接方便了顶层计算机用户的操作                          ,提升了用户体验                        。

2.2 什么是实时操作系统?

实时操作系统(Real-time operating system, RTOS)    ,又称即时操作系统                ,它会按照排序运行        、管理系统资源                          ,并为开发应用程序提供一致的基础        。

实时操作系统与一般的操作系统相比        ,最大的特色就是 “实时性                        ”            ,如果有一个任务需要执行                          ,实时操作系统会马上(在较短时间内)执行该任务             ,不会有较长的延时              。这种特性保证了各个任务的及时执行                         。

有关实时性的定义        ,可以参加维基百科的说法:

实时运算(Real-time computing)是计算机科学中对受到“实时约束        ”的计算机硬件和计算机软件系统的研究                         ,实时约束像是从事件发生到系统回应之间的最长时间限制            。实时程序必须保证在严格的时间限制内响应         。

往往我们评估一个实时操作系统是否足够优秀                  ,除了一些接口设计的人性化之外    ,其中一个很重要的特性就是评估其 实时性                          。毕竟在嵌入式开发领域                        ,某些项目场景下                      ,实时性可是整个系统的命脉,一旦出现 非实时 的缺陷                    ,可能问题就是致命的                。

3 常见常用的主流实时操作系统对比

根据上面的大类说法                          ,我们可以知道嵌入式操作系统并不一定都是实时操作系统    ,比如嵌入式Linux系统                ,它严格意义上就不是一个实时操作系统    。但不得不承认                          ,大部分的嵌入式操作系统都是实时操作系统                          。比如        ,我前文提及的 uCOS-II 操作系统                    。

本章节            ,我想给大家对主流的实时操作系统做个对比                          ,以便于后续大家做操作系统选型参考:

里面罗列总结的             ,不一定都对        ,仅供参考                         ,有疑问欢迎讨论。

4 工程中的实时操作系统

本章节                  ,我会从工程实践的角度    ,总结一下实时操作系统的几个核心模块                      。

这两年我自己一直在做嵌入式系统架构设计这块                        ,我们有个核心需求就是                      ,要求我们的代码在各个硬件平台,无论它跑什么嵌入式操作系统                    ,我们上层的应用代码都必须无缝衔接                        。

为了满足这样的需求                          ,我们的软件架构设计中    ,独立设计了一层叫 OSAL(Operation System Abstract Layer)                ,这一层它要解决的问题就是隔离具体的操作系统                          ,对上提供统一的操作系统接口    。

它的逻辑架构架构图如下所示:

下面针对这个OSAL层        ,简单介绍一下我们的设计:

其实要想把底层各式各样的操作系统隔离隔离开            ,那么我们必须识别出                          ,一般的操作系统都提供哪些系统能力             ,在这里我直接把我的答案写上来        ,欢迎大家补充                  。

操作系统的几个核心能力包括:

多任务(多线程):这是属于任务管理的范畴                         ,任何一个操作系统都必须提供类似的能力; 内存管理:严格来说                  ,这不是操作系统的专有模块    ,因为很多不上操作系统的工程也能看到类似的内存管理模块;但一般带操作系统的工程                        ,都有类似的内存管理模块; 互斥锁:这个基本是操作系统的必备能力                      ,用于对一些临界区资源的操作保护; 信号量:这个也是操作系统的必备能力,用于应对一些 逻辑同步 的应用场景; 消息队列:这个基本也是操作系统的标配                    ,用于解决不同线程            、任务直接的消息通讯问题; 事件组:这个可能不是每个操作系统都有                          ,它的作用有点类似于消息队列    ,但是它的实现比消息队列更轻量;用于实现多个事件同步; 定时器:这个也基本是操作系统的必选能力                ,用于提供给用户一些软件定时器的操作;

识别出了以上几个核心模块之后                          ,剩下的就是接口抽象设计了        ,我想这一块应该难不倒大家了                        。有兴趣的可以一起多交流交流        。

5 友情推荐

通过上面的介绍            ,大家对操作系统应该有一定的认识了                          ,但我想             ,仅仅了解这些是远远不够的              。

操作系统是一块很庞大的知识体系        ,建议大家系统地去学习一遍                         。

在这里我给大家推荐一本行业顶级的操作系统相关的工具书                         ,它就是 《操作系统:原理与实现》

本书的详细介绍                  ,可以参加我的 社区文章

6 文末福利

为了鼓励大家好好学习《操作系统》    ,我在我的技术社区组织赠书活动                        ,为大家送上五本《操作系统:原理与实现》                      ,大家感兴趣的 戳这里            。

声明:本站所有文章,如无特殊说明或标注                    ,均为本站原创发布         。任何个人或组织                          ,在未征得本站同意时    ,禁止复制                          、盗用             、采集        、发布本站内容到任何网站                         、书籍等各类媒体平台                          。如若本站内容侵犯了原著者的合法权益                ,可联系我们进行处理                。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
diff命令比较两个文件(bzdiff命令 – 比较两个.bz2压缩包中文件的不同)