码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 单片机测量任务运行时间


    前言

    1.之前是直接看定时器的计数值来粗略估计,可能会存在一些差错,也不够方便;所以做一个比较通用的计算任务运行时间的小Demo。

    2.用定时器的计数值查看开始的Tick和结束的Tick,然后定时器每隔1毫秒溢出一次,通过简单计算,求任务运行时间。

    3.在测到us级时存在误差,可能是一些语句执行需要时间,不过任务执行时间为us级,对单片机运行整体上没什么影响。

    3.毫秒级和秒级基本准确。

    有纰漏请指出,转载请说明。

    学习交流请发邮件 1280253714@qq.com


    runTime.h

    1. #ifndef __RUN_TIME_H
    2. #define __RUN_TIME_H
    3. #include "includes.h"
    4. typedef enum {
    5. TaskRunTime1 = 0,
    6. TaskRunTime2,
    7. TaskRunTime3,
    8. TaskRunTimeNum,
    9. } TaskRunTime_Num;
    10. typedef enum {
    11. TaskRunTimeStart,
    12. TaskRunTimeRunning,
    13. TaskRunTimeStop,
    14. } TaskRunTime_Flag;
    15. typedef struct {
    16. u32 startTick;
    17. u32 stopTick;
    18. u32 overFlowCnt;
    19. u32 runTime;
    20. TaskRunTime_Flag flag;
    21. } TaskRunTime_S;
    22. void TaskStartTick(TaskRunTime_Num taskx);
    23. void TaskStopTick(TaskRunTime_Num taskx);
    24. void TaskRunTimeOverFlow(void);
    25. #endif //__RUN_TIME_H

    runTime.c

    1. #include "includes.h"
    2. __IO TaskRunTime_S stRunTime[TaskRunTimeNum];
    3. void TaskStartTick(TaskRunTime_Num taskx)
    4. {
    5. memset(&stRunTime[taskx], 0, sizeof(TaskRunTime_S));
    6. stRunTime[taskx].startTick = TIM4->CNT;
    7. stRunTime[taskx].flag = TaskRunTimeStart;
    8. }
    9. void TaskStopTick(TaskRunTime_Num taskx)
    10. {
    11. s16 timeInterval = 0;
    12. stRunTime[taskx].stopTick = TIM4->CNT;
    13. stRunTime[taskx].flag = TaskRunTimeStop;
    14. timeInterval = (stRunTime[taskx].stopTick - stRunTime[taskx].startTick);
    15. stRunTime[taskx].runTime = 1000 * stRunTime[taskx].overFlowCnt + timeInterval;
    16. }
    17. void TaskRunTimeOverFlow(void)
    18. {
    19. for (int i=0; i
    20. {
    21. if (stRunTime[i].flag == TaskRunTimeStart)
    22. {
    23. stRunTime[i].overFlowCnt++;
    24. }
    25. }
    26. }
    27. void TIM4_IRQHandler(void)
    28. {
    29. if ( TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET )
    30. {
    31. TaskRunTimeOverFlow();
    32. TIM_ClearITPendingBit(TIM4 , TIM_FLAG_Update);
    33. }
    34. }

    演示

  • 相关阅读:
    统信 UOS 连接 Windows 共享打印机
    【QT 自研上位机 与 STM32F103下位机联调>>>通信测试-基础样例-联合文章】
    Java 第三阶段增强分析需求,代码实现能力【连接池】
    Python基于Excel生成矢量图层及属性表信息:ArcPy
    【RNA biology】RNA的多功能性与早期生命进化
    年薪百万架构师荐java面试宝典:spring/Redis/数据/Kafka/微服务
    备忘录模式
    不外传秘诀| docker 快速搭建常用的服务环境
    idea开发工具常用的插件合集汇总
    大视频文件的缓冲播放原理以及实现
  • 原文地址:https://blog.csdn.net/weixin_45817947/article/details/133050517
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号