嵌入式面试——FreeRTOS篇(二)

1、列表和列表项

答:

        列表FreeRTOS中的一个数据结构,概念上和链表有点类似,列表被用来跟踪FreeRTOS中的任务。

        列表项就是存放在列表中的项目。

        列表相当于链表,列表项相当于节点,FreeRTOS中的列表是一个双向环形链表。

2、列表(链表)和数组的区别

答:

  • 列表的特点:列表项间的地址非连续的,是人为的连接到一起的。列表项的数目是由后期添加或删除的个数决定的,随时可以改变。
  • 数组的特点:数组成员地址是连续的,数组在最初确定了成员数量后,后期将无法改变。

3OS中为什么使用列表

答:在OS中任务的数量是不确定的,并且任务状态是会发生改变的,所以非常适用列表(链表)这种数据结构。

4、列表API函数

5、任务切换的本质

答:

        任务切换的本质就是CPU寄存器内容的切换。假设当由任务A切换到任务B时,主要分为两步:

        第一步:需暂停任务A的执行,并且将此时任务A寄存器保存到任务堆栈中,这个过程叫做保存现场;

        第二步:将任务B的各个寄存器值(被存于任务堆栈中)恢复到CPU寄存器中,这个过程叫做恢复现场。

        对任务A保存现场,对任务B恢复现场,这个过程称为:上下文切换。

6PendSV中断是如何触发的

答:

1> 滴答定时器中断调用

2> 执行FreeRTOS提供的相关API函数:portYIELD()

3> 本质是通过中断控制和状态寄存器ICSRbit28写入1挂起PendSV来启动PendSV中的。

7、FreeRTOS的延时函数

答:FreeRTOS有两种延时函数:相对延时函数 绝对延时函数。

  • 相对延时:指每次延时都是从执行函数vTaskDelay()开始,直到延时指定的时间结束。
  • 绝对延时:指将整个任务的运行周期看成一个整体,适用于需要按照一定频率运行的任务。

注意:一般来说,绝对延时中的主体任务运行所需时间必须比绝对延时时间小。

8、延时函数的流程

答:

  • 正在运行的任务。
  • 调用延时函数。
  • 此时将该任务移除就绪列表,并添加到阻塞列表中。
  • 滴答中断里边进行计时。
  • 判断阻塞时间是否到达,如果到达将从阻塞列表移除,添加到就绪列表。

嵌入式开发中,FreeRTOS是一个常用的实时操作系统(RTOS)。它为嵌入式系统提供了多任务管理、任务调度、中断处理以及内存管理等功能。在面试中,针对FreeRTOS可能会有以下几个方面的问题: 1. 介绍FreeRTOS的特点和优势。 FreeRTOS具有以下几个特点和优势: - 轻量级:代码占用空间小,运行时内存消耗低。 - 可移植性:支持多种处理器架构和开发环境。 - 多任务管理:支持任务的创建、删除、挂起、恢复等操作。 - 任务调度:使用优先级和时间片轮转算法,实现任务调度。 - 中断处理:提供了中断处理机制,使得中断与任务可以协同工作。 - 内存管理:支持堆和栈的内存分配和释放,避免内存泄漏和碎片化。 - 丰富的组件:提供了定时器、信号量、消息队列等组件,方便开发。 2. 如何创建一个FreeRTOS任务? 在FreeRTOS中,可以使用函数xTaskCreate创建一个任务。该函数需要指定任务函数和任务的优先级等参数。例如: ``` void vTaskFunction(void *pvParameters) { // 任务函数的代码 } int main() { // 初始化系统和硬件 // ... // 创建任务 xTaskCreate(vTaskFunction, "TaskName", stackSize, NULL, priority, NULL); // 启动调度器 vTaskStartScheduler(); // 不会执行到这里 return 0; } ``` 3. 如何实现任务间的通信和同步? FreeRTOS提供了多种机制用于任务间的通信和同步,例如: - 信号量(Semaphore):用于任务间的同步和资源的保护。 - 互斥量(Mutex):用于任务间对共享资源的互斥访问。 - 队列(Queue):用于任务间的消息传递和数据共享。 - 事件标志组(Event Group):用于任务之间的事件通知和等待。 4. 如何处理中断和任务之间的关系? 在FreeRTOS中,中断处理和任务可以协同工作。可以使用函数xTaskResumeFromISR来从中断中恢复被挂起的任务。另外,还可以使用中断服务例程(ISR)向队列发送消息,然后由任务来处理这些消息。 总结来说,面试中关于FreeRTOS的问题可能会涉及其特点和优势、任务的创建、任务间的通信和同步、以及中断和任务之间的关系。熟悉这些方面可以更好地回答相关问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值