C语言运行一条语句所用时间如何计算?

 我来答
yinhuan99
推荐于2018-03-14 · 超过27用户采纳过TA的回答
知道答主
回答量:55
采纳率:0%
帮助的人:34.4万
展开全部
unsigned long HighStart,LowStart,HighEnd,LowEnd;
__int64 start =0;
__int64 end = 0;
__int64 timer =0;

//获取代码运行开始时cpu内部计数器的值
__asm
{
RDTSC
mov HighStart, edx
mov LowStart, eax
}
for(int i= 0; i<100000; i++ )
{
for(int i= 0; i<100000; i++ )
{

}
}
//获取代码结束时cpu内部计数器的值,并减去初值
__asm
{
RDTSC
mov HighEnd, edx
mov LowEnd, eax
}
start = (__int64) HighStart<<32;
start |= (__int64) LowStart;
end = (__int64) HighEnd<<32;
end |= (__int64) LowEnd;
timer = end - start;

//输出代码段运行的时钟周期数
//以频率1.1Gcpu为例,如果换计算机把其中的2.6改乘其它即可,因为相信大家的cpu都应该在1G以上 ^_^
cout<< (double) (timer /2.6/1000000000) << endl;
return 0;
tian_et
推荐于2016-06-23 · TA获得超过783个赞
知道小有建树答主
回答量:334
采纳率:0%
帮助的人:321万
展开全部
把time.h include进来
然后在代码的前面和后面都加一条代码,获得时间 long start=clock();
long end=clock();
两个减一下就是秒数
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
叁生万物
推荐于2016-03-27 · TA获得超过6259个赞
知道小有建树答主
回答量:2871
采纳率:41%
帮助的人:1025万
展开全部
把time.h include进来
然后在代码的前面和后面都加一条代码,获得时间 long start=clock();
long end=clock();
两个减一下就是秒数
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
sxsy556
2011-11-12 · TA获得超过1284个赞
知道小有建树答主
回答量:1037
采纳率:0%
帮助的人:654万
展开全部
使用time函数:
time函数举例
int main()
{
time_t t1,t2;
int i;
t1 = time(NULL);
for(i = 0;i<10000;i++)
;
t2 = time(NULL);
cout<<t2-t1<<endl;
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式