❶ 再问您 一个问题,51单片机上的C语言问题及uCOS问题.
那个uCOS-II是利用了宏开关。
例如:
Global.h文件里如下定义:
#ifdef
GLOBAL_VAR
unsigned
char
i_var;
#else
extern
unsigned
char
i_var;
#endif
如果在C文件里包含"Global.h"之前,先进行宏定义
#define
GLOBAL_VAR
#include
"Global.h"
那么,就相当于在
这个C文件里定义了
unsigned
char
i_var;
如果在包含之前,没有定义
GLOBAL_VAR
相当于,在这个C文件里引用了i_var,相当于:
extern
unsigned
char
i_var;
❷ 用ucos有什么好处吗
ucos ii是由Labrosse先生编写的一个开放式内核,最主要的特点就是源码公开,使用的好处在于,它是免费的,用户可以根据自己的需要对它进行修改。
❸ 单片机工业控制是用什么操作系统
单片机控制一般不用操作系统,但最好用FATFS文件系统,用操作系统的话多用ucos操作系统,也有用专用操作界面如emWin。
❹ free rtos和ucos的区别
一、freeRTOS比uCOS II优胜的地方: 1。 内核 ROM和耗费RAM都比uCOS 小,特别是RAM。 这在 单片机 里面是稀缺资源,uCOS至少要5K以上, 而freeOS用2~3K也可以跑的很好。 2。freeRTOS 可以用协程(Co-routine),减少RAM消耗(共用STACK)。uCOS只能用任务(TASK,每个任务有一个独立的STACK)。 3。freeRTOS 可以有优先度一样的任务,这些任务是按 时间片 来轮流处理,uCOSII 每个任务都只有一个独一无二的 优先级 。因此, 理论 上讲,freeRTOS 可以管理超过64个任务,而uCOS只能管理64个。 4。freeRTOS 是在商业上免费应用。uCOS在商业上的应用是要付钱的。 二、freeRTOS 不如uCOS的地方: 1。比uSOS简单,任务间通讯freeRTOS只支持Queque, Semaphores, Mutex。 uCOS除这些外,还支持Flag, MailBox. 2。uCOS的支持比freeRTOS 多。除 操作系统 外,freeRTOS只支持TCPIP, uCOS则有大量外延支持,比如FS, USB, GUI, CAN等的支持 3。uCOS可靠性更高,而且耐优化,freeRTOS 在我设置成中等优化的时候,就会出问题。 从别处看来的文章!❺ STM32单片机 ucos这个东西要怎么学啊
先把STM32学了,至少知道有些什么硬件资源,资源是怎么控制的;上了操作系统,说白了就和硬件层关系就不那么大了,所有的资源都交给操作系统去管理了,上边写程序都是用操作系统给的函数接口;当然驱动编写是离不开硬件的。所以先要把硬件学会,有硬件基础了,就好办了,刚开始是有些不习惯,因为上操作系统就有些偏软件了,里面有很多操作系统的机制一时还转换不过来。如果觉得理解不了可以先看看操作系统原理,把一些概念理解了。其实无论什么操作系统都是有共同点的,无非就是进程调度,进程间的同步与通信,内存管理和文件系统等等。慢慢的自己移植(现在移植都比较方便的汇编和CPU部分都基本是现成的了,这才是操作系统的根基),把操作系统里面的机制都用一遍,慢慢的就理解了。要相信,没有足够的准备和积累,是吃不下一大块肉的,不要急。
❻ 嵌入式与单片机之间的关系是什么
嵌入式与单片机之间的关系如下:
嵌入式系统是一个大类,单片机是其中一个重要的子类。嵌式系统像是一个完整的计算机,而单片机更像是一个没有外设的计算机。
以前单片机包括的东西并不算多,两者的硬件区别较为明显。但是,随着半导体技术的突飞猛进,现在各种硬件功能都能被做进单片机之中。所以,嵌入式系统和单片机之间的硬件区别越来越小,分界线也越来越模糊。
于是,人们倾向于在软件上进行区分。
从软件上,行业里经常把芯片中不带MMU(memory management unit,内存管理单元)从而不支持虚拟地址,只能裸奔或运行RTOS(实时操作系统,例如ucos、华为LiteOS、RT-Thread、freertos等)的system,叫做单片机(如STM32、NXP LPC系列、NXP imxRT1052系列等)。
同时,把芯片自带MMU可以支持虚拟地址,能够跑Linux、Vxworks、WinCE、Android这样的“高级”操作系统的system,叫做嵌入式。
在某些时候,单片机本身已经足够强大,可以作为嵌入式系统使用。它的成本更低,开发和维护的难度相对较小,尤其是针对一些针对性更强的应用。而嵌入式系统理论上性能更强,应用更广泛,但复杂度高,开发难度大。
嵌入式,一般是指嵌入式系统,嵌入式开发,就是对嵌入式系统的开发。IEEE(美国电气和电子工程师协会)对嵌入式系统的定义是:“用于控制、监视或者辅助操作机器和设备的装置”。
国内学术界的定义更为具体一些,也更容易理解:嵌入式系统,是以应用为中心,以计算机技术为基础,软件硬件可裁剪,适用于对功能、可靠性、成本、体积、功耗有严格要求的专用计算机系统。 以应用为中心,说明嵌入式系统是有明确实际用途的。
以计算机技术为基础,说明它其实就是一种特殊的计算机。软硬件可裁剪,说明它有很强的灵活性和可定制能力。
嵌入式系统的核心,就是嵌入式处理器。嵌入式处理器一般分为以下几种典型类型: 嵌入式微控制器MCU(Micro Control Unit) MCU内部集成ROM/RAM、总线逻辑、定时/计数器、看门狗、I/O、串口、A/D、D/A、FLASH等。典型代表是8051、8096、C8051F等。
嵌入式DSP处理器(Digital Signal Processor) DSP处理器专门用于信号处理,在系统结构和指令算法进行了特殊设计。在数字滤波、FFT、频谱分析中广泛应用。
典型代表是TI(德州仪器)公司的TMS320C2000/C5000系列。 嵌入式微处理器MPU(Micro Processor Unit) MPU由通用处理器演变而来,具有较高的性能,拥有丰富的外围部件接口。典型代表是AM186/88、386EX、SC-400、PowerPC、MIPS、ARM系列等。
此外,还有嵌入式片上系统SoC(System on Chip)和可编程片上系统SoPC(System on a Programmable Chip)。 我们的单片机,就属于上述的第一种——MCU(嵌入式微控制器)。
单片机,又称为单片微控制器,英文叫Single-Chip Microcomputer。它其实就是一种集成电路芯片,是通过超大规模集成电路技术,将CPU、RAM、ROM、输入输出和中断系统、定时器/计数器等功能,塞进一块硅片上,变成一个超小型的计算机。
单片机技术从上世纪70年代末诞生,早期的时候是4位,后来发展为8位,16位,32位。它真正崛起,是在8位时代。
8位单片机功能很强,被广泛应用于工业控制、仪器仪表、家电汽车等领域。我们在研究单片机的时候,经常会听到两个词——51单片机、STM32。我来介绍一下它们究竟是什么。
51单片机,其实就是一系列单片机的统称。该系列单片机,兼容Intel8031指令系统。它们的始祖,是Intel(英特尔)的8004单片机。
STM32,是意法半导体公司推出的基于ARM Cortex-M内核的通用型单片机。STM32的硬件配置可以满足大部分的物联网开发需求,开发工具和相关的文档资料齐全,已经成为目前单片机学习的首选对象。
❼ ucos移植到51单片机
第一,移植UCOS必须要了解编译器,我们一般使用的51编译器都是KEIL。值得一提的是KEIL对可重入函数的处理。由于51单片机的堆栈指针是8位的,所以硬件堆栈只能设置在内部RAM的DATA区和IDATA区(DATA、IDATA、PDATA、XDATA、CODE这些概念相关资料很多,我不想在此处滋述),所以51的堆栈是很紧张的。于是,KEIL将函数内的动态变量和函数传递的参数(当然有一部分参数是用寄存器直接传送的),放在分配的固定数据段中,函数执行时在固定的数据段中去取得相关的数据,而不是像传统的CPU都用堆栈来处理,这就导致了函数不可重入,因为当一个函数没执行完成时再次执行会把数据段里的内容覆盖掉。为了使函数可重入KEIL引入了仿真堆栈的概念(重入函数需在函数定义后面加上reentrant关键字),用仿真堆栈来传递参数及分配动态变量,就好像传统堆栈的入栈、出栈操作一般,如此函数第二次进入执行时,就不会覆盖掉上一次的变量和参数
❽ 用ucos有什么好处吗
多任务,相当你同时在用多几个单片机,可以用任务分解去写代码,更加简单,更加稳定。
调试也容易。