游戏电视苹果数码历史美丽
投稿投诉
美丽时装
彩妆资讯
历史明星
乐活安卓
数码常识
驾车健康
苹果问答
网络发型
电视车载
室内电影
游戏科学
音乐整形

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

  前言
  平时我们可能很少去关注程序运行的时间,但是在一些情况下可能需要对程序进行一个整体的复盘、优化。那么,程序运行的时间就是一个可以考虑的方面,可以测一下某些代码块、函数、算法的运行时间,然后整体考虑看看有没有必要进行优化。
  之前在某工控类项目中,我就有接到一个任务去测试程序中关键代码的执行时间,并输出报告。当时是使用一个GPIO示波器进行测试的,也可以使用逻辑分析仪来测。
  当时测量的方法很简单:在要测试的代码块函数之前设置该GPIO的电平为高电平,在要测试的代码块函数之后设置该GPIO为低电平,使用示波器测高电平的时间,就知道了这一代码块函数的运行时间。下面就通过实例来介绍一下这种简单而有效的方法。
  我这里使用逻辑分析仪来测量,使用小熊派开发板来验证,小熊派的主控为STM32L431RCT6,系统时钟设置为80MHz。
  这里顺带提一点题外话,之前有一些初学的读者朋友问我说逻辑分析仪贵不贵。逻辑分析仪有贵的也有便宜的,贵则上千上万元,便宜则有几十、几百。我觉得无论工作、还是学习,都有必要入手一个逻辑分析仪。
  本篇笔记的测试用的逻辑分析仪就是某宝上二十几块钱买的,可以满足平时的学习所用。条件有限的学生朋友可以入手。有条件的可以考虑入手几百块钱的。GPIO逻辑分析仪测时间1、测量HALDelay函数
  STM32的HAL库有给我们提供一个HALDelay延时函数,这是一个ms级延时函数。这个延时函数依赖于系统滴答定时器,所以是一个比较精确的延时函数。这里,我们就使用GPIO逻辑分析仪的方法来测量一下这个延时函数。为了方便测试,我们在while死循环里进行测量。
  代码:
  测量结果:
  可见,我们通过逻辑分析仪测出了HALDelay(100);运行的时间为100。4315ms,符合我们的预期。这里高电平两侧其实就是低电平部分,只不过低电平持续的时间太短了,在这里看起来像一条竖线,我们放大来看看:
  结果已经很准了,可以满足平时的测量。这种测量很难保证百分之百的精确,小数点后面的那一部分可能是受很多不可控因素的影响,这不在我们本篇文章的讨论范围之内。
  我们是想通过这个示例来介绍这种测量方法的使用及证明这种方法是可行的。下面再继续看两个实例。测量软件延时函数
  我们以前刚开始学单片机的时候,经常有用到一些粗略的延时函数,其实现方法就是循环执行n条空语句,以达到一个延时的效果。那么,我们怎么来构造一个us级或ms级的粗略延时函数(软件延时函数)。我们之前看到的粗略延时函数类似这样子:
  这些函数里面需要给出一些循环的次数,这个值是怎么来确定的呢?比如上面这个函数中123这个值是怎么来确定的?我们可以使用GPIO逻辑分析仪的方法来进行一个简单的确定。
  确定1us:
  不同的处理器,结果是不一样的。针对小熊派开发板(主控:STM32L431RCT6),循环运行15条空语句的时间实测结果是1。083us,这算是比较接近1us了。我们就运用这个结果来构建一个us级软件延时函数如下:
  接下来我们测一下softdelayus(100);实际运行了多长时间:
  可见,结果差不多接近我们想要的结果。构建这样的粗略延时函数可以使用这样的方式来确定一些循环次数的值。对比查表法与常规法的运行时间
  在之前的文章:空间换时间,查表法的经典例子中,我们有说可以适当使用查表法降低程序的执行时间。这里我们来实际测量对比一下那篇文章中查表法与常规法的优劣。
  关键代码:测试结果structtestres{unsignedintdata;数据unsignedintcount;数据中1的个数};常规法if1structtestresgettestres(unsignedintdata){保存测试结果structtestresres;保证数据总会在00xf之间unsignedinttempdata0xf;unsignedinttempdata0xff;res。count0;res。datatemp;循环判断每一位for(inti0;i16;i){if(temp0x01){res。count;}temp1;}returnres;}else查表法inttable〔16〕{0,1,1,2,1,2,2,3,1,2,2,3,2,3,3,4};structtestresgettestres(unsignedintdata){保存测试结果structtestresres;保证数据总会在00xf之间unsignedinttempdata0xff;获取低4位中1的个数unsignedintlowdatatemp0xf;unsignedintlowcnttable〔lowdata〕;获取高4位中1的个数unsignedinthighdata(temp4)0xf;unsignedinthighcnttable〔highdata〕;结果res。countlowcnthighcnt;res。datatemp;returnres;}endifintmain(void){USERCODEBEGIN1structtestresres{0};省略部分代码while(1){USERCODEENDWHILEUSERCODEBEGIN3HALGPIOWritePin(GPIOA,GPIOPIN2,GPIOPINSET);resgettestres(30);HALGPIOWritePin(GPIOA,GPIOPIN2,GPIOPINRESET);}USERCODEEND3}
  常规法程序的运行时间:
  查表法程序的运行时间:
  可见,这个例子中常规法程序运行时间约为2ns,而查表法程序运行时间约为500ns。查表法的程序运行之间仅为常规法的14,省下了34的时间。随着调用次数的增多,这里的查表法的优势越大。比如循环计算031这32个数中每一个数二进制位为1的个数,则相关代码改为:inti;while(1){HALGPIOWritePin(GPIOA,GPIOPIN2,GPIOPINSET);for(i0;i32;i){resgettestres(i);}HALGPIOWritePin(GPIOA,GPIOPIN2,GPIOPINRESET);}
  常规法:
  查表法:
  可见,随着调用次数的增多,查表法相对于常规法更省时,即查表法的优势越大。
  以上就是关于GPIO逻辑分析仪测程序运行时间的几个实例。下面顺带提一下使用MDKSTLINK测STM32程序运行时间的方法。MDKSTLINK测时间
  在使用MDK作为开发工具时,可以搭配一些仿真器来查看程序执行时间。这里通过实例来介绍MDKSTLINK测STM32程序运行时间的方法。
  这里重点是设置Trace里面的系统内核时钟,我们这里使用的是小熊派开发板(主控:STM32L431RCT6),并且配置的系统时钟是80MHz:
  所以在Trace中要设置为80MHz。这个得根据实际芯片的型号就需要根据进行修改,比如STM32F103系列默认是72MHz,STM32F429系列默认为180MHz等,根据实际进行修改。
  下面我们通过在线调试、打断点的方式看一下HALDelay(1000);运行了多长时间:
  可见程序运行到HALDelay(1000);前后的时间分别为:前:0。00008964s后:1。00108161s
  即HALDelay(1000);走过的时间约为1s,符合预期。
  以上就是本次的分享,如有错误,欢迎指出!感谢阅读

如果苹果和华为都不是中国品牌,大家会选择哪个品牌的手机呢?感谢邀请如果苹果和华为都不是中国品牌,大家会选择哪个品牌的手机呢?我觉得结果应该没有太多的悬念,因为按照题主的假设华为是国外的品牌,估计很多人都不会去看一眼的。因为华为之……有了智能手机,你多长时间没看过电视了?我会经常看电视的,但是仅限于CCTV13这个台,只会看新闻别的从来不会看的。比较关注时事新闻和国内外的事物。如果有时间每天都会看新闻联播的不爱看电视倒不是主要因为手……宝能汽车好消息不断,造车这件事它玩明白了私家车驶入千家万户,对于车企来说是一大利好,市场需求的释放,如今已然引得广大企业加入造车这一热门赛道之中。宝能集团,一家实力雄厚的大型现代化企业集团,从2017年正式宣告造车开……业绩亮眼机构认可的腾讯阿里巴巴跌出全球市值前十2021年3月份全球市值十大上市公司市值排行榜。据外媒最新报道,腾讯市值约为5520亿美元,根据彭博汇编的数据,这略低于排名第10名美国芯片制造商辉达的市值(5590亿美……我喜欢用手机拍风景,不知道什么品牌的手机好?感谢您的阅读!我喜欢用手机拍风景,不知道什么品牌的手机好?我相信很多人都喜欢用手机拍风景,毕竟手机会非常的方便便于携带,你外出旅行的时候,你带上你的相机可能会比较笨拙,而……小米继手机以后再超苹果,直接登顶全球第一!网友好样的众所周知,因为手环、智能手表等兴起,现在的消费者已经越来越不喜欢带传统的电子机械手表了。而在智能手表、手环流行的当前,中国厂商凭借着物美价廉的产品,以及中国庞大的市场,也……Apple何时会向所有人发布iOS15。4?OS15。4目前正在面向开发者和公众用户进行Beta测试,更新包括一系列诱人的新功能。虽然任何人都可以加入Apple的beta测试计划,但许多人更愿意等待漏洞被解决后的公开发布……突破技术壁垒!首个中国二维码国际标准发布为什么不用二维码?因为我只用中国的汉信码。汉信码准确地说,是中国版的二维码。二维码本身是一个舶来品,最初于20世纪80年代中期在美国问世,90年代中期发展成熟,相继……高新技术介入教学过程的伦理评价对于我国大陆教师课堂教学方法信念支柱:宣讲灌输,教育部前陈部长是否定的,并认为我国目前这种教学方法百分之九十是无效的,命令在每个教室里安装摄像头。最高领导的教育哲学观念也进行调……华为nova9SE屏幕尺寸6。78英寸支持100W快充今日华为商城100W超级快充页面支持机型中显示了还未发售的华为nova9SE,由此看来新机将支持100W快充。另外nova9SE的上手图也被曝光,其采用居中挖孔屏设计,看上去边……买车一个月被罚了3次,什么感觉?很多新手买了新车,一个月就被罚了三次,非常正常,因为你对交通法规熟悉程度,和实际操作有所不同,如果只是简单的违章罚款,心里还可以承受,要是扣分再罚款,而是顶额罚款,就有买车后悔……亚马逊将更新FBA货件政策4月1日起生效1、亚马逊将更新FBA货件政策4月1日起生效亚马逊美国站发布公告称自2022年4月1日起将更新FBA货件政策,错误操作将延迟库存到库及影响上架时间,亚马逊建议卖家遵循新F……
TVB台庆剧跳跃生命线优酷今晚同步上线马德钟上演制服杀星关系10月8日讯由香港广播电视有限公司(TVB)拍摄制作,方骏钊监制、马德钟领衔主演、何广沛、张曦雯、刘佩玥、陈滢、罗天宇、李佳芯、张文慈联合主演的职业剧《跳跃生命线》将于今……首部内地TVB同步播剧集跳跃生命线定档10。8马德钟何广沛上星关系9月26日讯香港TVB最新医疗剧《跳跃生命线》由方骏钊监制,马德钟领衔主演,何广沛、张曦雯、刘佩玥、陈滢、罗天宇、李佳芯、张文慈联合主演。该剧为2018TVB巡礼剧集之一……玲珑本周火热收官演员陈语安长文告别由企鹅影视和唐人影视共同出品的古装玄幻剧《玲珑》正在热播,该剧讲述了在一块名为宿川的大陆上,一对父女与一众少年在冒险中共同成长进步,并肩守护热土,收获爱与希望并迎风而立带领宿川……赘婿中的最美婶婶出圈演员樊昱君厚积薄发作为2021年开年大戏的第一个赢家,电视剧《赘婿》在观众的追捧声中完美收官。在这部欢乐魔性的剧集里,不少角色给观众留下了深刻的印象,比如一袭红衣、英姿飒爽的压寨夫人邵仙英,她看……邻家诗话第二季收官高口碑传播诗词文化近日,由腾讯视频、河北卫视、一心明德文化联合出品的诗歌实景雅集类文化综艺节目《邻家诗话》第二季,正式收官,观众们纷纷表示感受到了中华文化的博大精深,看完简直有点自豪。作为……RedmiNote10外观公布,配备VC液冷散热满血版UFS近日,Redmi官方在宣发预热的过程中,正式公布了RedmiNote10幻青配色的外观。从图片来看,幻青配色的后盖部分整体采用立体光栅工艺,呈现出纵向3D纹理。辅以青蓝色……冻肉怕风干!海尔博观冰箱风冷不风干通过不断循环的冷风保鲜食材,这是风冷冰箱的储鲜逻辑。虽然温度更均衡、免去了结霜的烦恼,但存在易风干食材的弊端。第33周行业数据显示,风冷冰箱的年累份额已达到94。3。如此……TCL华为红米大PK!哪款98英寸的巨幕智屏更值得购买?在目前大尺寸智屏的消费市场中,98英寸是一名普通的用户所能买到的极限尺寸。把98英寸的巨幕智屏搬回家,已经不再是一件遥不可及的事情。早在数年前,小米的子品牌红米Redmi就发布……上阳赋最吸睛青年演员魏子涵护妹又英勇疯狂圈粉由侯咏担任总导演、程源海担任导演,罗松担任总编剧,章子怡、周一围、于和伟、杨祐宁领衔主演,实力派青年演员魏子涵特别出演的古装剧《上阳赋》正于优酷热播。该剧改编自寐语者的小说《帝……只需动一个开关,就可以关闭Windows11开始菜单中的推荐根据微软的透露,将在今年晚些时候(大概是10月份)正式发布Windows11,但在此之前,随意Windows11测试版的不断发布,win11已经引起了大量的兴趣和争论。微软最新……如果iPhone13最终让你ampampquot囊中羞涩am笔歌科技独家报道:iPhone13系列马上就要发布了,相关外观设计和性能配置已经基本曝光了,现在就剩下公布一个售价了,这也是当前大家很关心的一个问题了,一起来围观。01苹……鹿鼎记七个老婆杂志大片网友张一山福气大了随着节假日的结束,新版《鹿鼎记》的开拍日期也逐渐临近,近日,网曝剧中韦小宝7个老婆的杂志大片,图片中,七美不仅个个貌美如花,霞姿月韵,更是各有各的独特魅力,百花齐放,有网友调侃……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网