范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

分享一种简单实用的测量程序运行时间的方法

  前言
  平时我们可能很少去关注程序运行的时间,但是在一些情况下可能需要对程序进行一个整体的复盘、优化。那么,程序运行的时间就是一个可以考虑的方面,可以测一下某些代码块、函数、算法的运行时间,然后整体考虑看看有没有必要进行优化。
  之前在某工控类项目中,我就有接到一个任务去测试程序中关键代码的执行时间,并输出报告。当时是使用一个GPIO+示波器进行测试的,也可以使用逻辑分析仪来测。
  当时测量的方法很简单:在要测试的代码块/函数之前设置该GPIO的电平为高电平,在要测试的代码块/函数之后设置该GPIO为低电平,使用示波器测高电平的时间,就知道了这一代码块/函数的运行时间。下面就通过实例来介绍一下这种简单而有效的方法。
  我这里使用逻辑分析仪来测量,使用小熊派开发板来验证,小熊派的主控为STM32L431RCT6,系统时钟设置为80MHz。
  这里顺带提一点题外话,之前有一些初学的读者朋友问我说逻辑分析仪贵不贵。逻辑分析仪有贵的也有便宜的,贵则上千上万元,便宜则有几十、几百。我觉得无论工作、还是学习,都有必要入手一个逻辑分析仪。
  本篇笔记的测试用的逻辑分析仪就是某宝上二十几块钱买的,可以满足平时的学习所用。条件有限的学生朋友可以入手。有条件的可以考虑入手几百块钱的。GPIO+逻辑分析仪测时间1、测量HAL_Delay函数
  STM32的HAL库有给我们提供一个HAL_Delay延时函数,这是一个ms级延时函数。这个延时函数依赖于系统滴答定时器,所以是一个比较精确的延时函数。这里,我们就使用GPIO+逻辑分析仪的方法来测量一下这个延时函数。为了方便测试,我们在while死循环里进行测量。
  代码:
  测量结果:
  可见,我们通过逻辑分析仪测出了HAL_Delay(100);运行的时间为100.4315ms,符合我们的预期。这里高电平两侧其实就是低电平部分,只不过低电平持续的时间太短了,在这里看起来像一条竖线,我们放大来看看:
  结果已经很准了,可以满足平时的测量。这种测量很难保证百分之百的精确,小数点后面的那一部分可能是受很多不可控因素的影响,这不在我们本篇文章的讨论范围之内。
  我们是想通过这个示例来介绍这种测量方法的使用及证明这种方法是可行的。下面再继续看两个实例。测量软件延时函数
  我们以前刚开始学单片机的时候,经常有用到一些粗略的延时函数,其实现方法就是循环执行n条空语句,以达到一个延时的效果。那么,我们怎么来构造一个us级或ms级的粗略延时函数(软件延时函数)。我们之前看到的粗略延时函数类似这样子:
  这些函数里面需要给出一些循环的次数,这个值是怎么来确定的呢?比如上面这个函数中123这个值是怎么来确定的?我们可以使用GPIO+逻辑分析仪的方法来进行一个简单的确定。
  确定1us:
  不同的处理器,结果是不一样的。针对小熊派开发板(主控:STM32L431RCT6),循环运行15条空语句的时间实测结果是1.083us,这算是比较接近1us了。我们就运用这个结果来构建一个us级软件延时函数如下:
  接下来我们测一下soft_delay_us(100);实际运行了多长时间:
  可见,结果差不多接近我们想要的结果。构建这样的粗略延时函数可以使用这样的方式来确定一些循环次数的值。对比查表法与常规法的运行时间
  在之前的文章:空间换时间,查表法的经典例子中,我们有说可以适当使用查表法降低程序的执行时间。这里我们来实际测量对比一下那篇文章中查表法与常规法的优劣。
  关键代码:/* 测试结果 */ struct test_res {     unsigned int data;  /* 数据          */     unsigned int count; /* 数据中1的个数 */ }; ​ /* ============常规法============ */ #if 1 struct test_res get_test_res(unsigned int data) {     /* 保存测试结果 */     struct test_res res;          /* 保证数据总会在0~0xf之间 */     // unsigned int temp = data & 0xf;        unsigned int temp = data & 0xff;               res.count = 0;     res.data = temp;          /* 循环判断每一位 */     for (int i = 0; i < 16; i++)     {         if (temp & 0x01)         {             res.count++;         }         temp >>= 1;     }          return res; } #else /* ============查表法============ */ ​ int table[16] = {0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; ​ struct test_res get_test_res(unsigned int data) {     /* 保存测试结果 */     struct test_res res;          /* 保证数据总会在0~0xf之间 */     unsigned int temp = data & 0xff;               /* 获取低4位中1的个数 */     unsigned int low_data = temp & 0xf;     unsigned int low_cnt = table[low_data];          /* 获取高4位中1的个数 */     unsigned int high_data = (temp >> 4) & 0xf;     unsigned int high_cnt = table[high_data];          /* 结果 */     res.count = low_cnt + high_cnt;     res.data = temp;          return res; } #endif int main(void) {   /* USER CODE BEGIN 1 */   struct test_res res = {0};        /* 省略部分代码… */        while (1)   {   /* USER CODE END WHILE */   /* USER CODE BEGIN 3 */     HAL_GPIO_WritePin(GPIOA, GPIO_PIN_2, GPIO_PIN_SET);     res = get_test_res(30);     HAL_GPIO_WritePin(GPIOA, GPIO_PIN_2, GPIO_PIN_RESET);   }   /* USER CODE END 3 */ }
  常规法程序的运行时间:
  查表法程序的运行时间:
  可见,这个例子中常规法程序运行时间约为2ns,而查表法程序运行时间约为500ns。查表法的程序运行之间仅为常规法的1/4,省下了3/4的时间。随着调用次数的增多,这里的查表法的优势越大。比如循环计算0~31这32个数中每一个数二进制位为1的个数,则相关代码改为:  int i;   while (1)   {     HAL_GPIO_WritePin(GPIOA, GPIO_PIN_2, GPIO_PIN_SET);     for (i = 0; i < 32; i++)     {       res = get_test_res(i);     }     HAL_GPIO_WritePin(GPIOA, GPIO_PIN_2, GPIO_PIN_RESET);   }
  常规法:
  查表法:
  可见,随着调用次数的增多,查表法相对于常规法更省时,即查表法的优势越大。
  以上就是关于GPIO+逻辑分析仪测程序运行时间的几个实例。下面顺带提一下使用MDK+ST-LINK测STM32程序运行时间的方法。MDK+ST-LINK测时间
  在使用MDK作为开发工具时,可以搭配一些仿真器来查看程序执行时间。这里通过实例来介绍MDK+ST-LINK测STM32程序运行时间的方法。
  这里重点是设置Trace里面的系统内核时钟,我们这里使用的是小熊派开发板(主控:STM32L431RCT6),并且配置的系统时钟是80MHz:
  所以在Trace中要设置为80MHz。这个得根据实际芯片的型号就需要根据进行修改,比如STM32F103系列默认是72MHz,STM32F429系列默认为180MHz等,根据实际进行修改。
  下面我们通过在线调试、打断点的方式看一下 HAL_Delay(1000);运行了多长时间:
  可见程序运行到HAL_Delay(1000);前后的时间分别为:前:0.00008964s 后:1.00108161s
  即HAL_Delay(1000);走过的时间约为1s,符合预期。
  以上就是本次的分享,如有错误,欢迎指出!感谢阅读

老游新荐当年我仙剑奇侠传1也是很能打,很有精神的仙剑奇侠传是由大宇资讯于1995年发售的一款全汁全味的中文角色扮演类游戏。这款游戏无论是美术剧情玩法都对后来的中文角色扮演类游戏产生了重要的影响,影响有多大呢?大到现在还有许多游戏京津冀打工人不见踪影?因为这三点,大多数人都不愿意来了引言要说到城市群,可能很多人并不熟悉,其实正常情况下一般有三个或者是三个以上的大城市作为核心组成的城市集群,便被很多人称为城市群。当然,如果按照我国目前的发展形势来看,最终城市群的农村低保不再有,改了新名字后,这3类人不能申请引言虽然我国的城市化进程不断发展,但农村人口依然是一个庞大数字。在农村中有一些人因为身体条件无法找到工作或是丧失劳动力,所以在农村当中这部分人日常生活水平是很差的,劳动能力低下或没口袋奇兵X变形金刚品牌联动活动上线首日打破游戏单日收入记录2021年8月10日,由孩之宝大中华区独家电子化授权合作伙伴全球游戏服务平台游道易公司推进并促成的口袋奇兵X变形金刚品牌全球联动合作正式上线。游道易协助新锐游戏开发者江娱互动,在孩明年新生儿连1000万都达不到?90后都不愿意生了,原因是什么?引言国家实行计划生育政策也好几十年了,若放在八九十年代基本上每家每户都有三四个孩子,但现在国家放开二胎和三胎,从政策上减轻了人们生育的压力,目前没有计划生育了,但仔细观察一下周围身同样是联动仙剑,为什么这款游戏在玩家心中的评价如此之高?盘点曾经和仙剑联动的那些游戏,你是否有过爷青回?作为曾经陪伴了无数人的经典武侠游戏IP,仙剑系列的游戏在国人玩家心中的地位之高是毋庸置疑的。而这也导致了在如今的游戏市场中,有很多游单机新作获好评但仙剑的下一步计划远不止于此仙剑奇侠传七的发售引起全网热议,也让这个熟悉的名字重回大众视野。这个历经起伏的国民IP,时至今日依然有着不可思议的生命力。改变一代玩家的游戏习惯的传奇之作在国产游戏的历史上,仙剑奇一个大学教师是如何在游戏中变成独裁者的?说起EVE这款游戏相信有不少玩家对其应该略有耳闻,但是因为其过于硬核的玩法,即使很多老玩家愿意去帮助新玩家,却也因为所需要投入过高的时间成本,导致新玩家的增长量一直不多。不过,随着EVE即将走出专制时代?EVE手游各大联盟正逐渐走向一超多强一直以来在大部分的网游中,顶级玩家往往容易让玩家们产生崇拜之情,但是在EVE这款游戏当中,却有一个人让不少玩家对其感到深深的恐惧。EVE和其他所有的游戏很不相同,虽然从另一个角度来女性向游戏都是缝纫机转世吗?时装内卷,随便一套完爆香奈儿高定随着越来越多的女性玩家加入到游戏大军,游戏市场也马不停蹄地研发着各种女性向的部分,比如女性玩家喜爱的游戏时装,就甚得芳心。不仅是大众类型的王者荣耀女角色越做越美,现在市场上女性向手物价疯涨,钱越来越不值钱,普通人该怎样自保?引言在上个世纪很长一段时间内,我国的经济发展比较缓慢,物价上升也比较慢。新世纪经济腾飞之后随着和世界各国的经济融合物价上涨已经不是完全靠国内产品成本所主导的了,比如一些国际大宗商品
经验分享丨六步交易法,或许能助你稳定盈利刚开始,交易给人的压力会很大,还有更多困惑时常袭来。不过,任何将辛苦赚来的钱置于风险中的工作,都会让人产生压力,时常恐惧担忧,遇到需要做决定的时候都会慌乱。但是,也不必总是这样消极华人顶级交易员分享这23个交易经验让我的交易更上一层楼RaynerTeoRaynerTeo是独立交易员,曾经是一名自营交易员。他交易历史接近12年时间了。如今他自己的交易博客相当受欢迎。他主要跟随趋势进行交易。他认为,除了交易技巧和策公务支出公款消费审计的八项经验分享笔者结合审计工作实践,就公务支出公款消费审计的重点内容浅谈几点认识。一进一步明确公务支出及公款消费审计的内容首先,根据相关要求,公务支出公款消费的概念进一步明确了,三公经费的内涵丰基于移动端的视频监控系统如何实现?视频监控已经融入了民众生活的方方面面,生活中有小区安全监控,通信行业有基站监控,银行系统有柜台监控,林业部门有火情监控,交通方面有违章和流量监控。从功能上讲,视频监控的运用是非常广SUV添猛将,轴距2800带188Ps,超CS75Plus哈弗H6作为SUV领域的领头羊,从推出以来哈弗h6销量就一直居高不下,基本上是稳坐SUV销量榜榜首,而且其市场表现面对其竞争对手一直是有着巨大的优势,直到去年长安汽车推出的CS75蓝鲸家族再添猛将,1。5T有180Ps油耗6。3L,关键顶配11。39w长安汽车作为老牌的自主汽车品牌,近些年的发展可谓是相当迅猛,尤其是近两年来发布的一些新车型,不少都已经成为了爆款,其中像长安CS75plus换装蓝鲸系列发动机的逸动极具未来科技感的全新suv将上市,150马力油耗5。6L轴距2651,看到车标又是爆款大众作为国内最受消费者青睐的汽车品牌,在国内不管是有着南大众之称的上汽大众,还是有着北大众之称的一汽大众,都有着极高的市场地位,南北大众单独拿出来其市场表现都让其它车企只能望其项背家用代步两不误,出了名的抗造省油空间大,8月26日上市在当前国内汽车市场的格局中,日系和德系汽车品牌可以说是最受消费者欢迎。其中德系的驾驶质感是占据优势,但要论及家用,日系车的皮实抗造省油省心的特点一直是被誉为家用车首选,而日系车拥有真给国产车长脸,一脚油门完爆卡宴,轴距2820,看啥汉兰达保时捷卡宴作为中型SUV性能车中的典范,可以说是拥有着不少的忠粉,尤其是Turbo的Macan,凭借4。5S破百的超强性能,更是让不少消费者对其念念不忘!不过落地百万的价格,只能让国产SUV谍照曝光,搭190马力的1。5T,轴距或超2720紧凑级SUV一直是自主品牌竞争中最为激烈的细分领域,而且也是自主品牌所占市场份额最多的车型,如果能够推出一款成功的紧凑级SUV,甚至可以养活一个车企,就比如哈弗来说,凭借哈弗h6的长安是狠人,空间叫板汉兰达,人脸识别十佳引擎,不足8w边听边读效果更佳断头今日意如何?创业艰难百战多。此去泉台招旧部,旌旗十万斩阎罗。上面引入的这段诗词,是截取自陈毅将军梅岭三章中的四句非常经典且励志的句子。作为无产阶级革命家军事家外