如何在C++程序中实时输出程序运行时间,而且不影响其他程序功能

如何在C++程序中实时输出程序运行时间,而且不影响其他程序功能,第1张

1、使用clock函数获得程序开始和结束的时间,相减就能得到程序运行的时间。

clock()是C/C++中的计时函数,而与其相关的数据类型是clock_t。在MSDN中,查得对clock函数定义如下:

clock_t clock(void)

简单而言,就是该程序从启动到函数调用占用CPU的时间。这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数,在MSDN中称之为挂钟时间(wal-clock);若挂钟时间不可取,则返回-1。其中clock_t是用来保存时间的数据类型。

例程:

#include

#include

using namespace std

int main()

{

clock_t start,finish

start=clock()

cout <<"HW .... " <<endl

finish=clock()

cout <<finish-start <<"/" <<CLOCKS_PER_SEC <<" (s) "<<endl

return 0

}

3、转http://zhidao.baidu.com/link?url=RgBrnkPuCJvY9k_jzzJoCeNrfQo3RBNYFHEkADdoboUV-T6CFjx2EolTJ-XkdkQ1ed9zwkm6GQdOj_3qN8LTxXA8j7zOiwng7TvYgf9eUfy

结构体的大小不能简单认为就是成员的叠加..!!!

所以你fprintf(“%d”)并不是说数据存文本里面就占四个字节,只是用10进制打印出来,可能是1个字节,也可能是5个字节,你fprintf("%s"),虽然长度在实际上就是24+1个字节,但是结构体中组织数据是需要对齐的.. temp2[25]占用内存是28个字节,因为是32位机,数据一般会四个字节对齐...对一个字节也是这样..自己看看sizeof(struct shijian)的大小....

fprintf("%4d")

fprintf("%28s")

用格式输出保证这个10进制数字的字符串占4个字节,这个时间的字符串占28个字节

这样就把文本的数据组织的和结构体一样大了..

调试的时候看看到底读出了多少个字节...fread你可以把单元设置为1,这样就能自己看读出出多少个字节,fread给你算了你当然看不到细节...

#include<stdio.h>

#include<time.h>

#include<string.h>

int main(int argc,char *argv[])

{

time_t timep1

struct shijian

{

int number

char timep2[25]

}

FILE *fp=NULL

if ((fp=fopen("1.txt","a+"))==NULL)

{

printf("can not open !")

return -1

}

struct shijian shijian[200]

int i=1

int rc

while(i==1 &&rc <10000)//rc超出10000的话,程序就又会不对劲了...只给了4个位

{

rc=fread(shijian,sizeof(struct shijian),200,fp)

// fflush(fp)

shijian->number=rc+1

// shijian->number=i

// i=rc

time(&timep1)

strcpy(shijian->timep2,ctime(&timep1))

printf("%d %s\n",shijian->number,shijian->timep2)

// fwrite(q->number,sizeof(q->number),1,fp)

// fflush(fp)

fprintf(fp,"%4d",shijian->number)fflush(fp)

fprintf(fp,"%28s",shijian->timep2)fflush(fp)

// fwrite(shijian->timep2,sizeof(shijian->timep2),1,fp)

rewind(fp)

sleep(3)

// fseek(fp,0,SEEK_SET)

// (shijian->number)++

}

fclose(fp)

return 0

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8137258.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存