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

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

  前言
  平时我们可能很少去关注程序运行的时间,但是在一些情况下可能需要对程序进行一个整体的复盘、优化。那么,程序运行的时间就是一个可以考虑的方面,可以测一下某些代码块、函数、算法的运行时间,然后整体考虑看看有没有必要进行优化。
  之前在某工控类项目中,我就有接到一个任务去测试程序中关键代码的执行时间,并输出报告。当时是使用一个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,符合预期。
  以上就是本次的分享,如有错误,欢迎指出!感谢阅读

最早iPhone14就能用了!苹果被曝或推出硬件订阅服务随着时代的进步,智能手机的售卖方式也在不断发生着变化。比如,智能机刚开始出现的时候,最流行的是合约机,也就是那些年常说的充话费送手机。虽然后来逐渐不流行了,但是却留下了不少名梗,其运动手环推荐大家好,我是小温。现在越来越多人注重运动这一块,运动手环的出现可以实时代替生活中我们看不到的内容。小温为大家带来几款性价比较高的运动手环。OPPO智能手环,我认为这款手环性价比较高安洁科技董秘氢燃料电池核心零部件目前正在研发及产能建设中安洁科技(002635)03月28日在投资者关系平台上答复了投资者关心的问题。投资者请问董秘您好贵公司有哪些核心技术是全球领先的?是否有控股子公司被评为或获得专精特新小巨人?安洁科国信期货崔谷纯秉承技术引领业务理念加强打造信息技术核心竞争力中证网讯(记者周璐璐)国信期货2018年4月成立电子商务部,由6人组成的业务团队在客户开发客户开户技术运维系统开发等方面各司其职,通力合作。技术如何给传统经纪业务赋能,期货电子商务欢迎购买华为4G手机如果你的钱是大风刮来的,本文不适合你阅读,欢迎你去购买某位网友口中的苹果8G手机。一没有网络,只有手机,这样的手机你会买吗?网络重要,还是手机重要?估计读者莫衷一是!我认为网络比手社交电商的四种典型商业模式实体经济双重受挫的后疫情时代,思购臻选社交电商社交电商有哪些模式,各自的特点是什么?社交电商不是简单的社交电商,它的形态可分为很多种第一种电商社交电商社交的模式主要有两种一种是本来画风反转!一年给骑手补贴近140亿,美团竟成了良心企业?在曾经,一提起美团,骑手消费者和商家都是口吐芬芳,消费者认为美团上面的商品定价远高于线下,骑手则认为美团不断缩减送餐时间来压榨他们的体力,而商家则觉得美团抽成太高,卖一单就亏一单。部分地区楼市成交有所回升!多个互联网巨头被曝大裁员1,十大券商政策底市场底已经出现,A股将逐步企稳并进入中期上行通道A股已从情绪驱动回归基本面驱动的常态,并将进入政策的关键发力期近两周来疫情对经济影响较大,稳增长政策发力的必要性和红米K50Pro和小米11价格差不多,怎么选择?建议选择红米K50Pro,去年小米11的口碑实在太差了,由于火龙888的影响,烧WiFi日常发热问题比较严重,前期销量虽然不错,但后期口碑崩盘了。而红米K50Pro的天玑9000在使用Selenium抓取zabbix性能监控图概要老样子先来个概要,因为公司一直都子使用企业微信,前两天刚刚将所有zabbix的告警信息接到微信上,总感觉还差那么一点,就想着就高等级的告警加上一个性能监控图,这样只看告警信息大曝接近真全面屏三星S23Ultra,三星S22彻底让路,价格突然骤降曝光不负众望为行业带来更有创新力三星S23Ultra机皇的渲染图流出,曝光不负众望为行业带来更有创新力三星S23Ultra机皇设计上有了跨越式提升。曝光不负众望为行业带来更有创新力
跨境电商是什么?新手怎么做跨境电商?一文便知跨境电商是什么?跨境电商分为出口跨境电子商务和进口跨境电子商务。通过电子商务平台达成交易进行支付结算,并通过跨境物流送达商品完成交易的一种国际商业活动。我国跨境电子商务主要分为企业自动驾驶带火激光雷达市场多笔重磅融资事件发生随着自动驾驶商业化和规模化的进一步落地,激光雷达作为自动驾驶和高级驾驶辅助系统的核心硬件之一,也迎来了发展新机遇。自2021年伊始,激光雷达领域已有多笔重磅融资事件发生,再次引起了售27。6万!首批ampampquot标续ampampquot特斯拉ModelY开始交付表显满电续航440km日前,我们从多个渠道获知,首批标准续航版国产ModelY车型将于本周开始交付,有大量早期下单的用户收到了特斯拉销售人员的交付通知。新车于7月8日在特斯拉中国官网正式上线,补贴后售价阿里的花名,真的是为了去人格化吗?(本文首发于刘润公众号,关注刘润,和170万读者一起洞察商业本质)阿里最近频上热搜,导致很多人讨论他们的花名制度。有人认为,花名的目的是去人格化。其实不是。花名背后的目的,是去权威摩托罗拉edgespro素皮高配版明日首发12256GBIT之家8月16日消息摩托罗拉宣布,摩托罗拉edgespro素皮版(青玉案配色)12GB256GB版本明日首次发售。按照之前发布会的定价,预计售价为3299元。IT之家了解到,摩托新版NBMiner解锁GeForceRTX30LHR系列部分挖矿算力在今年五月份,英伟达宣布推出GeForceRTX30LHR系列GPU,其LHR是LiteHashRate的缩写,意味着新版GPU将具有新版加密货币挖矿限制器,包括后来推出的GeFo错过海信激光电视,我选择了峰米C2在激光电视的大屏观影潮流之下,我也打算为家里装上一台大屏的激光电视。在对比选择的时候,身边的很多朋友都向我推荐海信激光电视,说是海信激光电视品牌的知名度更高,旗下的海信激光电视75苹果秋季发布会细节曝光iPhone可能要被迫取消Lightning充电口你们好,这里是Seek思科,为你寻找苹果最新资讯苹果隐藏技巧苹果良心APP以及苹果优质配件。如果你需要这些,不妨点个关注。目前普遍认为苹果今年秋季将会发布包括新款iPhoneApp为游戏而生,小米K40轻薄机身,硬核造型获好评小米手机我们都知道,一旦运行大软件或者是使用时间长就会发热,真的应了logo为发烧而生。因为此事,小米也是遭到很多网友的嘲笑。小米没有因此就放弃手机市场,而是通过努力,让手机不再因小米平板5Pro评测苦等了三年,到底值得买吗?8月10日晚的小米秋季新品发布会上,小米带来了两个久未见面的老朋友。一个是拖更了许久的小米MIX4手机,一个是一度被人以为要遗弃的小米平板系列。在阔别了平板市场3年之后,小米平板5苹果iPhone13系列或与12系列售价保持一致今天早些时候,据彭博社MarkGurman称,苹果计划在今年秋季举办多场活动,推出新款iPhoneAppleWatchSeries7AirPods第3代第6代iPadmini第9代