当前位置: 首页 > article >正文

单片机能运行操作系统吗?

先直接上答案:可以!

但是操作系统不是刚需,上操作系统比较占用单片机的资源,比如占用比较多的FLASH和RAM,间接增加了硬件成本,哪怕成本增加1毛钱,对于上量的产品,分分钟是一个工程师的工资。

我做了单片机开发10几年,大多数产品其实还是裸机编程,用到操作系统的比较少。

当然,这个跟产品功能有关,一般产品功能复杂、实时性要求苛刻的就会上操作系统。

目前用的比较多的就是实时操作系统,比如主流有uC/OS-II、FreeRTOS、rt-thread。

下面,简单给大家说下3个系统各自优缺点,如有不对,请指正!

一、uC/OS-II

uC/OS-II 是 Micrium 公司开发的商业实时操作系统,它的内核设计非常稳定和可靠,更加注重调度算法和系统服务的丰富性,适合于需要更高实时性和稳定性的应用。

uC/OS-II 的优缺点如下:

特点:

对开发友好:资料多。

实时性:uC/OS-II 可以提供非常快速的中断响应和任务切换,确保系统实时性。

可移植性:uC/OS-II 可以支持多种不同的处理器架构,使得应用程序更易于移植到不同的硬件平台上。

可靠性:由于 uC/OS-II 的内核设计非常稳定和可靠,因此它被广泛应用于各种不同的嵌入式系统中。

成熟的生态环境:由于 uC/OS-II 已经发布了很长时间,因此它的社区和生态环境非常成熟和完善,用户可以方便地获取文档、示例和支持。

缺点:

商业授权费用:uC/OS-II 是一个商业实时操作系统,用户需要购买商业授权才能使用。

资源占用:uC/OS-II占用单片机资源较多,需要较大的存储空间和内存空间。

另外,开发者是可以剪裁的,也就是说你可以根据你产品的功能修改系统代码做定制,前提是你已经吃透了系统的代码,否则不要轻易尝试,不然很容易给自己挖坑。

二、 FreeRTOS

FreeRTOS 是一个开源的实时操作系统,目前占有率高。

特点:

商业授权费用:可以免费商用

轻量级:FreeRTOS 的内核非常小巧,适合资源受限的单片机。

实时性:FreeRTOS 可以提供非常快速的中断响应和任务切换,确保系统实时性。

可移植性:FreeRTOS 可以支持多种不同的处理器架构,使得应用程序更易于移植到不同的硬件平台上。

社区支持:FreeRTOS 的社区非常活跃,有大量的开发人员参与开发和维护,使得 FreeRTOS 的生态环境非常完善。

良好的文档和资料:FreeRTOS 的文档和资料非常丰富,学习和使用 FreeRTOS 相对较为简单。

缺点:

组件少:部分功能组件不够完善,比如GUI(图形界面)、TCP/IP、文件系统需外扩第三方。

三、rt-thread

这个是国内一款适合物联网产品的实时操作系统,特点是资源占用极低(1.2KB RAM和3KB Flash),代码架构做低功耗功能比较方便。

优点:

轻量级:RT-Thread 的内核非常小巧,适合资源受限的单片机。

实时性:RT-Thread 可以提供非常快速的中断响应和任务切换,确保系统实时性。

可裁剪性:RT-Thread 可以按需选择需要的组件,以减小系统占用的资源。

面向对象:RT-Thread 支持对象化编程,使得代码更加清晰易懂。

跨平台支持:RT-Thread 可以支持多种不同的处理器架构。

缺点:

生态相对不够完善:相比一些成熟的嵌入式操作系统,RT-Thread 的社区和开发人员数量相对较少,生态环境相对不够完善。

学习曲线较陡峭:RT-Thread 是一个相对较新的操作系统,它的文档和资料相对较少,学习曲线相对较陡峭。

不适合大型系统:由于 RT-Thread 的内核设计初衷是轻量级和实时性,所以它不适合构建大型的嵌入式系统。

四、自己对RTOS的理解

最后聊一下,我对这些实时操作系统的理解。

我觉得实时操作系统,本质上就是一个实时性高的程序架构

实时就是能保证我的任务规定的时间内去执行,这用传统while(1)轮询方式是实现不了的。

程序架构就好比建房子时的地基,只有地基稳了,才能应对外在恶劣环境对房子造成的影响,比如台风、地震。

我们写程序也是一样的,程序架构就是的”地基”,只有地基稳了,你的程序才能应对项目经理突如其来的改功能、换芯片方案,你的代码才经得起折腾、产品功能做得稳定。

可惜啊,很多工程师并没有写程序架构的能力,因为对经验和代码水平要求比较严格。

所以一般复杂的项目,直接上现成的、稳定的实时操作系统就可以了。

这样至少可以保证两点:

1.程序架构上不出问题。

2.程序的实时性不出问题。

不过用现成的也是有缺点的,就是RTOS的功能很多,有很多你产品压根用不上,但是你没办法,你又不会剪裁,这样就会浪费你很多单片机资源。

所以这几年我做项目,一直是用自己写的程序架构,然后程序实时性通过人工去规避。

比如任务初始化、创建、调度管理。

还有实时操作系统一些实用功能,比如队列,也是产品常用的,只是我自己写了更简化的代码。

这套架构的教程我暂时无偿提供给大家学习,很早之前录制的,后面可能会删掉。

这套程序架构最大的好处就是简易占用单片机资源少、移植性强,适用于各种单片机,包括有些51单片机。

不过本质是时间片轮询,不带任务优先级抢占,对实时性要求非常苛刻的项目就不合适了,有兴趣的可以自己修改代码实现。

教程获取方法可以看我下面这篇文章的开头

《单片机入门到高级开挂学习路径(附教程+工具)》

《单片机入门到高级开挂学习路径(附教程+工具)》

《单片机入门到高级开挂学习路径(附教程+工具)》


http://www.kler.cn/a/1252.html

相关文章:

  • 哈利·波特是谁?大型语言模型中的近似取消学习
  • 从CentOS到龙蜥:企业级Linux迁移实践记录(系统安装)
  • 通过gradle发布aar或jar携带sources-jar到maven nexus
  • Dart语言的语法糖
  • 二、智能体强化学习——深度强化学习核心算法
  • 《解锁图像的语言密码:Image Caption 开源神经网络项目全解析》
  • GPT-4,终于来了!
  • JVM高频面试题
  • 对象的动态创建和销毁以及对象的复制,赋值
  • 深入剖析Linux——进程信号
  • SpringCloud五大核心组件
  • Python每日一练(20230318)
  • 深入理解 Go slice 扩容机制
  • Redis基础篇
  • Spring 事务(编程式事务、声明式事务@Transactional、事务隔离级别、事务传播机制)
  • Spring事务和事务传播机制
  • 插件化架构设计(2):插件化从设计到实践该考量的问题汇总
  • 菱形继承和C++相关问题
  • React 用一个简单案例体验一遍 React-dom React-router React-redux 全家桶
  • Springboot集成Swagger
  • 公司测试员用例写得乱七八糟,测试总监制定了这份《测试用例编写规范》
  • 【高阶数据结构】红黑树
  • css属性学习
  • Java基础之常见运算符
  • 77.qt qml-QianWindow-V1版本界面讲解
  • @JsonFormat与@DateTimeFormat