OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4072|回复: 12

如何测试一段代码或整段代码的运行时间,有相关例程吗?

[复制链接]

3

主题

10

帖子

0

精华

新手上路

积分
43
金钱
43
注册时间
2018-7-5
在线时间
4 小时
发表于 2018-7-30 16:22:25 | 显示全部楼层 |阅读模式
5金钱
由于没有买仿真器,想测试一下代码运行时间。求指教

最佳答案

查看完整内容[请看2#楼]

不需要例程,用SYSYTICK就行了。设置SYSTICK为1ms中断一次 //nTicks为一个32位的静态全局变量,用于累计SysTick总次数 static u32 nTicks = 0; //静态全局变量只在本文件有作用 u32 GetTicks() { return nTicks; } /* SysTick中断服务函数 */ void SysTick_Handler(void) { nTicks++; } 在需要测试的代码运行前及运行后,分别调用GetTicks();两次相减就是运行时间。 如果你的代码非常短,不够1ms的话,就要设 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

31

主题

1955

帖子

3

精华

论坛元老

Rank: 8Rank: 8

积分
4524
金钱
4524
注册时间
2018-5-11
在线时间
947 小时
发表于 2018-7-30 16:22:26 | 显示全部楼层
不需要例程,用SYSYTICK就行了。设置SYSTICK为1ms中断一次
//nTicks为一个32位的静态全局变量,用于累计SysTick总次数
static u32 nTicks = 0;  //静态全局变量只在本文件有作用
u32 GetTicks()
{
        return nTicks;
}

/* SysTick中断服务函数 */
void SysTick_Handler(void)
{
        nTicks++;
}

在需要测试的代码运行前及运行后,分别调用GetTicks();两次相减就是运行时间。
如果你的代码非常短,不够1ms的话,就要设置SYSTICK为更短的中断周期了。
我的开源链接 https://github.com/ShuifaHe/STM32.git  请关注,点赞支持哦。
回复

使用道具 举报

9

主题

796

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2038
金钱
2038
注册时间
2017-8-2
在线时间
522 小时
发表于 2018-7-30 17:26:41 | 显示全部楼层
楼上正解
回复

使用道具 举报

3

主题

10

帖子

0

精华

新手上路

积分
43
金钱
43
注册时间
2018-7-5
在线时间
4 小时
 楼主| 发表于 2018-8-5 18:44:03 | 显示全部楼层
warship 发表于 2018-7-30 16:22
不需要例程,用SYSYTICK就行了。设置SYSTICK为1ms中断一次
//nTicks为一个32位的静态全局变量,用于累计Sys ...

好,谢谢
回复

使用道具 举报

56

主题

520

帖子

0

精华

高级会员

Rank: 4

积分
964
金钱
964
注册时间
2014-11-18
在线时间
160 小时
发表于 2018-8-6 15:54:03 | 显示全部楼层

我一般都是用IO在while1里翻转。然后用示波器看。      
自己选择的路,成家前走完。
回复

使用道具 举报

0

主题

28

帖子

0

精华

高级会员

Rank: 4

积分
762
金钱
762
注册时间
2018-7-25
在线时间
276 小时
发表于 2018-8-6 17:14:51 | 显示全部楼层
要比较精确的话可以在代码的前后各加一个断点,查看CYCLECOUNTER寄存器的值,根据CPU频率就可以算出来了
回复

使用道具 举报

13

主题

38

帖子

0

精华

初级会员

Rank: 2

积分
100
金钱
100
注册时间
2017-4-29
在线时间
19 小时
发表于 2018-8-15 15:42:13 | 显示全部楼层
路上捡到一只猫 发表于 2018-8-6 17:14
要比较精确的话可以在代码的前后各加一个断点,查看CYCLECOUNTER寄存器的值,根据CPU频率就可以算出来了

请问CPU频率在哪里看?计算公式是什么?
回复

使用道具 举报

20

主题

227

帖子

0

精华

高级会员

Rank: 4

积分
605
金钱
605
注册时间
2017-7-14
在线时间
116 小时
发表于 2018-8-15 15:55:25 | 显示全部楼层
2楼正解,5楼方法也可以,可以不用示波器,用逻辑分析仪。
也可以在函数前后用串口输出,打开时间戳(但这个没有前面两个方法精确)
回复

使用道具 举报

0

主题

28

帖子

0

精华

高级会员

Rank: 4

积分
762
金钱
762
注册时间
2018-7-25
在线时间
276 小时
发表于 2018-8-16 09:09:47 | 显示全部楼层
yangguang32 发表于 2018-8-15 15:42
请问CPU频率在哪里看?计算公式是什么?

就是系统时钟,得看自己配置的是多少了
回复

使用道具 举报

15

主题

406

帖子

0

精华

高级会员

Rank: 4

积分
795
金钱
795
注册时间
2015-3-26
在线时间
151 小时
发表于 2018-8-16 09:14:41 | 显示全部楼层
调试器都没有,怎么跟踪代码。
回复

使用道具 举报

1

主题

882

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3071
金钱
3071
注册时间
2018-2-7
在线时间
285 小时
发表于 2018-8-16 09:58:20 | 显示全部楼层
keil中选择软件仿真,然后打开  Performance Analyzer 窗口,单步执行,可以看到每一行代码的执行时间。
keil仿真.jpg
回复

使用道具 举报

20

主题

227

帖子

0

精华

高级会员

Rank: 4

积分
605
金钱
605
注册时间
2017-7-14
在线时间
116 小时
发表于 2018-8-21 09:57:00 | 显示全部楼层
今天想到一个简单的办法。keil下选中软件仿真。设定好软件的晶振。
然后在代码前后加上一个变量高低电平,仿真时打开软件逻辑分析仪,添加该变量即可。
回复

使用道具 举报

37

主题

477

帖子

2

精华

金牌会员

Rank: 6Rank: 6

积分
2285
金钱
2285
注册时间
2017-8-24
在线时间
375 小时
发表于 2018-8-21 11:52:21 | 显示全部楼层
用一个定时器,程序运行前后分别读cnt寄存器的值,要注意溢出问题,再计算
天然懒,天然呆
能吃会睡,未来可期
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-11 20:28

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表