当前位置:首页 > > 糖果Autosar
[导读]1、程序框架简介根据多年的编程经验来看,单片机的程序框架大体分为三种分别是顺序执行架构、分时轮询架构和RTOS。顺序执行架构:该框架或许是我们大部分初学者最常用的一种代码编写格式了,比如说首先执行我们的按键检测,然后执行显示数码管,然后去做其他事情!这样一个任务一个任务执行,任务...

1、程序框架简介

根据多年的编程经验来看,单片机的程序框架大体分为三种分别是顺序执行架构分时轮询架构RTOS。
顺序执行架构:该框架或许是我们大部分初学者最常用的一种代码编写格式了,比如说首先执行我们的按键检测,然后执行显示数码管,然后去做其他事情!这样一个任务一个任务执行,任务较少时该架构比较简单稳定,当任务比较复杂,逻辑分析就相对比较麻烦,而且程序之间耦合也比较大!需要开发者对程序足够的熟悉,且不便于扩展!
分时轮询架构:这可能是大部分有一定编程基础的程序员或者对小资源单片机进行开发所选用的一种程序架构,今天这也是我们介绍的主题,后面会进行详细介绍。
RTOS:这可能是大部分单片机编程老鸟所选用的一种架构了,RTOS对任务的管理非常丰富,能够让CPU获得一个更大的利用率!那么我们常用的有FreeRTOS,uCos,等等,一般会获得商业使用权等等,也有免费的!
上述的程序框架,各有优劣,需要我们根据具体的情况来选用对应的框架!

2、分时轮询框架详解

从名字上看该框架是通过时间事件发出消息,主任务通过轮流查询对应的时间事件进行运行,因为我们大部分的状态程序都是以时间为节点进行转移和控制的,那么该框架就能够使用,并且我们的中断仅仅是外部给予的一种信号,我们对应的中断服务函数里面进行处理便好,比如:我们的串口接受,当相应接受中断,我们便可以接受到缓存,然后置位相应的标志位,时间任务便会查询、处理。
缺点:该框架的缺点也是很明显的,就是对任务中特殊事件的处理不够及时,不过对于大部分我们大部分项目都还是可以接受的,并不需要实时的处理!
好了,废话不多说,上代码!
//TaskManage.h


#ifndef __TASKMANAGE__
#define __TASKMANAGE__

/************************************************************
* Fuction :数据类型定义区
* Author  :(公众号:最后一个bug)
***********************************************************/
#define TRUE (1)
#define FALSE (0)

#ifndef NULL
#define NULL ((void*)(0))
#endif

typedef unsigned int u32;
typedef unsigned short u16;
typedef unsigned char u8;
typedef signed long s32;
typedef signed short s16;
typedef signed char s8;

typedef volatile unsigned int vu32;
typedef volatile unsigned short vu16;
typedef volatile unsigned char vu8;

typedef volatile unsigned int const vuc32; /* Read Only */
typedef volatile unsigned short const vuc16; /* Read Only */
typedef volatile unsigned char const vuc8; /* Read Only */


/************************************************************
* Fuction :任务类型定义区
* Author  :(公众号:最后一个bug)
***********************************************************/
#define TASK_NUM_MAX 20

//运行模式
#define TASK_STOP (0)
#define TASK_RUN  (1)

/************************************************************
* Fuction :类型定义区
* Author  :(公众号:最后一个bug)
***********************************************************/
#pragma pack(1)
typedef struct _tag_taskdata
{
u8  statue; //运行状态
u32 time; //运行周期
u32 count_time; //运行计数变量
void (*fuc)(void); //运行函数指针
} stTaskData;

typedef struct _tag_taskmanage
{
stTaskData task[TASK_NUM_MAX]; //最大任务数管理
u8 registerTaskNum; //已经注册的任务
}stTaskManage;
#pragma pack()


/************************************************************
* Fuction :功能接口区域
* Author  :(公众号:最后一个bug)
***********************************************************/
extern void InitialTaskManager(void);
extern u8  RegisterTask(u32 time, void * taskFuc);
extern void Task_Process(void);
extern void Task_RunCheck(void);

#endif




//TaskManage.c


#include "TaskManage.h"

/************************************************************
* descri  : 变量定义区
* Author  :(公众号:最后一个bug)
***********************************************************/
stTaskManage sTaskManage;

/************************************************************
* Fuction : InitialTaskManager
* descri  : 初始化任务管理
* Author  :(公众号:最后一个bug)
***********************************************************/
void InitialTaskManager(void)
{
u8 i = 0;
for(i = 0;i< TASK_NUM_MAX;i )
{
sTaskManage.task[i].statue     = TASK_STOP; //运行标识
sTaskManage.task[i].time       = 0; //运行周期
sTaskManage.task[i].count_time = 0; //运行计数变量
sTaskManage.task[i].fuc        = NULL; //运行函数指针
}

sTaskManage.registerTaskNum = 0; //已经注册的任务计数清零
}

/************************************************************
* Fuction : RegisterTask
* descri  : 注册任务
* Author  :(公众号:最后一个bug)
***********************************************************/
u8  RegisterTask(u32 time, void * taskFuc)
{
if(sTaskManage.registerTaskNum >= TASK_NUM_MAX)return FALSE;
if(taskFuc == NULL)return FALSE;

if(sTaskManage.task[sTaskManage.registerTaskNum].fuc == NULL) //找到没有使用的任务数据
{
sTaskManage.task[sTaskManage.registerTaskNum].statue     = TASK_STOP; //运行状态
sTaskManage.task[sTaskManage.registerTaskNum].time       = time; //运行周期
sTaskManage.task[sTaskManage.registerTaskNum].count_time = 0; //运行计数变量
sTaskManage.task[sTaskManage.registerTaskNum].fuc        = taskFuc; //运行函数指针

sTaskManage.registerTaskNum ;//已经注册的任务计数
return TRUE;//注册成功
}

return FALSE; //全部注册完毕

}

/************************************************************
* Fuction : Task_Process
* descri  : 任务处理过程
* Author  :(公众号:最后一个bug)
***********************************************************/
void Task_Process(void)
{
u8 taskcount= 0;
//遍历已经注册的任务
for(taskcount = 0; taskcount < sTaskManage.registerTaskNum;taskcount )
{
if(sTaskManage.task[taskcount].statue == TASK_RUN)//任务可以运行
{

(*sTaskManage.task[taskcount].fuc)();
sTaskManage.task[taskcount].statue = TASK_STOP;
}

}

}

/************************************************************
* Fuction : Task_RunCheck
* descri  : 任务运行条件核对
* Author  :(公众号:最后一个bug)
***********************************************************/
void Task_RunCheck(void)
{
u8 taskcount= 0;
//遍历已经注册的任务
for(taskcount = 0; taskcount < sTaskManage.registerTaskNum;taskcount )
{
if(( sTaskManage.task[taskcount].count_time) >= sTaskManage.task[taskcount].time) //任务时间到来
{
sTaskManage.task[taskcount].count_time = 0;
sTaskManage.task[taskcount].statue     = TASK_RUN;

}

}

}




//使用例程


#include
#include "TaskManage.h"

/************************************************************
* Fuction : Task1
* descri  : 任务1
* Author  :(公众号:最后一个bug)
***********************************************************/
void Task1(void)
{
printf("Run Task_1\n");
}
/************************************************************
* Fuction : Task2
* descri  : 任务2
* Author  :(公众号:最后一个bug)
***********************************************************/
void Task2(void)
{
printf("Run Task_2\n");
}
/************************************************************
* Fuction : Task3
* descri  : 任务3
* Author  :(公众号:最后一个bug)
***********************************************************/
void Task3(void)
{
printf("Run Task_3\n");
}



int main(int argc, char *argv[])
{
u16 SimuTime = 0;

InitialTaskManager();
RegisterTask(10,Task1);
RegisterTask(20,Task2);
RegisterTask(50,Task3);

while(1)
{
Task_Process();

//模拟定时器中断中调用该函数
if(( SimuTime) <= 100)
{
Task_RunCheck();

}
else
{
break;
}

}

printf("最后一个bug");
return 0;

}
好了,我们的代码和测试文件代码都已经粘贴上去了,感兴趣的小伙伴可以进行移植、测试和扩展,这里我也附上我的运行现象大家尝个鲜!如下图所示:

该测试程序是100个时间基数任务执行情况,任务1和任务2的时间比例是1:2,任务1与任务3的时间比例也是1:5,刚好与我们注册时候的时间是一致的!







本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭