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
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)