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

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

时间2025-05-01 22:28:06分类IT科技浏览3510
导读:使用了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
芒果tv会员有优惠吗多少钱啊(芒果TV会员有何附加功能及2种会员的区别) 海洋cms使用教程(深入探索海洋CMS二次创作教程)