打印

c程序执行多少时间

[复制链接]
7459|22
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
llia|  楼主 | 2011-5-9 09:14 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
就是每条c语句等于多少机器周期
沙发
wangpe| | 2011-5-9 09:20 | 只看该作者
用keil u3,debug调试,然后查看汇编窗口,里面就是对应c程序的汇编代码.每条语句对应的机器周期是不一样的

使用特权

评论回复
板凳
langgq| | 2011-5-9 09:44 | 只看该作者
Keil自己有运行时间记录功能吧

使用特权

评论回复
地板
wangzsa| | 2011-5-9 10:05 | 只看该作者
想得到自己C程序的汇编码,也不用到调试窗口:只要在你的C程序第一条输入
#pragma  src(your_name.a51)

然后把your_name.a51文件加到项目窗口就可以看到汇编码了。

使用特权

评论回复
5
llia|  楼主 | 2011-5-9 10:25 | 只看该作者
还有这功能啊 我得试试  谢谢楼上的大哥

使用特权

评论回复
6
zhuww| | 2011-5-9 10:53 | 只看该作者
看看反汇编 然后找本汇编的书,自己算算

使用特权

评论回复
7
wangzsa| | 2011-5-9 11:18 | 只看该作者
如若遇到for,if 这类语句,怎么计算?如若程序有2,000条,20,000汇编语句,怎么自己算?

使用特权

评论回复
8
zhanglli| | 2011-5-9 13:12 | 只看该作者
难道your_name.a51的内容  与  通过调试窗口看到的反汇编内容不一样么?

使用特权

评论回复
9
lium| | 2011-5-9 13:28 | 只看该作者
our_name.a51是宏汇编源代码,读懂它就知道宏汇编分段分模块编程策略。调试窗口已经将各个模块连接成一体,一个大模块,若是几万行的代码,把你看晕。

但是在项目窗口下的your_name.a51里却可以分模块修改,特别是由多个程序员共同完成的大的应用项目。

使用特权

评论回复
10
guoyt| | 2011-5-9 13:47 | 只看该作者
测时间,研究具体多少语句没有太大意义,可以估计1行C=7行汇编。

使用特权

评论回复
11
zepper| | 2011-5-9 14:08 | 只看该作者
反汇编出来看~~

使用特权

评论回复
12
hanwe| | 2011-5-9 14:11 | 只看该作者
这个不定,不能一概而论。跟架构相关,跟你的上下文相关,同时跟编译器的效率也相关。比如说在arm中一个32位立即数的加载指令的机器周期就可能是一条,也可能是两条。
很多相同功能的语句,如果编译器没有优化,不能的写**导致不一样的编译长度,例如for(i = 10; i > 0; i --)
的最终指令数就要少于for(i = 0; i < 10; i ++)
最准确的结果还是要看你最终编译出来的二进制文件的map表。

使用特权

评论回复
13
zhuww| | 2011-5-9 14:33 | 只看该作者
很多相同功能的语句,如果编译器没有优化,不同的写法导致不一样的编译长度,例如for(i = 10; i > 0; i --)


没事呀?

使用特权

评论回复
14
wangzsa| | 2011-5-9 14:55 | 只看该作者
两种写法都是正确的,不过在没有优化的情况下会有不同的编译长度。

使用特权

评论回复
15
yufe| | 2011-5-9 15:06 | 只看该作者
利用断点计算,在这条语句的前面加一个断点。运行程序,然后在你要计算的语句的后面加个断点。再运行,两次时间相减,就行了。查看时间,在keil软件上有,很精确的

使用特权

评论回复
16
wangpe| | 2011-5-9 15:24 | 只看该作者
一般而言,我们所写的C程序都要放到相应的编译程序中去编译,但是一般编写的C程序很难一次就能编译成功,必须通过反复调试才能通过,我曾经使用过伟福系列仿真系统里面的编译和汇编都可以,而且,配合“程序时效分析功能”很容易知道你的每段程序的执行时间,然而此时最好把你的开发板和仿真器相连,采用硬件仿真,这样基本上可以知道所写程序的基本运行情况。

使用特权

评论回复
17
langgq| | 2011-5-9 15:49 | 只看该作者
是啊,
   当然,采用Keil uVision2的功能先将正确的C程序编译通过,再将生成的HEX文件通过反汇编成汇编语言,再计算每条语句的的执行时间,算出整个程序执行时间也可,但无论如何,你的程序执行时间一定取决于其所对应的硬件环境。

使用特权

评论回复
18
wangzsa| | 2011-5-9 16:05 | 只看该作者
嗯,也有道理

使用特权

评论回复
19
llia|  楼主 | 2011-5-9 16:12 | 只看该作者
多谢各位大侠指点

使用特权

评论回复
20
luoluo0018| | 2011-5-9 17:38 | 只看该作者
都不错

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

961

主题

8893

帖子

4

粉丝