首先是对文件的操作fopen,打开文件并返回文件指针fp。最后使用完fclose(fp),否则造成内存泄漏。
fseek(fp,0,SEEK_END);//把指针移到最后
len=ftell(fp);//获取文件指针长度,实际是就是文件的长度。
实战例子
void write_log( const char * buffer)
{
FILE *fp;
long fl;
time_t c_time;
tm *pt1;
char file_name[100],file_name1[100];
char cmd[256];
sprintf(file_name,"%s/log/trans.log",HomePath);
sprintf(file_name1,"%s/log/trans.log.old",HomePath);
sprintf(cmd,"mv %s %s",file_name,file_name1);
fp = fopen(file_name, "a+");
if( fp==NULL )
{
printf("can't open %s, error !\n", file_name);
}
else
{
fseek(fp, 0L, SEEK_END);
fl=ftell(fp);
if( fl>1024L*1024L*20L )
{
fclose(fp);
system(cmd);
fp=fopen(file_name, "a");
}
if( fp!=NULL )
{
time(&c_time);
pt1=localtime(&c_time);
fprintf(fp, "\n !! <<time:%d-%d-%d %d:%d:%d>> \n",pt1->tm_year+1900, pt1->tm_mon+1, pt1->tm_mday,pt1->tm_hour, pt1->tm_min, pt1->tm_sec);
fprintf(fp, "%s\n", buffer);
fclose(fp);
}
}
}