
你的意思是指每隔一秒或几秒输出你要的监控信息是吧?
两种方式:
写sh脚本,用while循环,sleep 1 ;然后执行你的那个命令,最后执行你的sh脚本,这个应该能理解的吧。
用命令自带的功能,比如free命令,用free -h,查看到有-s 每隔几秒输出和 -c 总共输出几次退出,则命令如下:free -s 1 -c 10,这样就会每隔一秒输出一次,总共输出十次后退出。
希望能帮到你,如有问题,请直接问我,喜欢请采纳和点赞哈。
结构体的大小不能简单认为就是成员的叠加..!!!所以你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条)