Linux下怎么做秒执行任务

Linux下怎么做秒执行任务,第1张

你好,每隔三秒:

* * * * * /home/somedir/scripts.sh

* * * * * sleep 3 &&/home/somedir/scripts.sh

* * * * * sleep 6 &&/home/somedir/scripts.sh

* * * * * sleep 9 &&/home/somedir/scripts.sh

* * * * * sleep 12 &&/home/somedir/scripts.sh

* * * * * sleep 15 &&/home/somedir/scripts.sh

* * * * * sleep 18 &&/home/somedir/scripts.sh

* * * * * sleep 21 &&/home/somedir/scripts.sh

* * * * * sleep 24 &&/home/somedir/scripts.sh

* * * * * sleep 27 &&/home/somedir/scripts.sh

* * * * * sleep 30 &&/home/somedir/scripts.sh

* * * * * sleep 33 &&/home/somedir/scripts.sh

* * * * * sleep 36 &&/home/somedir/scripts.sh

* * * * * sleep 39 &&/home/somedir/scripts.sh

* * * * * sleep 42 &&/home/somedir/scripts.sh

* * * * * sleep 45 &&/home/somedir/scripts.sh

* * * * * sleep 48 &&/home/somedir/scripts.sh

* * * * * sleep 51 &&/home/somedir/scripts.sh

* * * * * sleep 54 &&/home/somedir/scripts.sh

* * * * * sleep 57 &&/home/somedir/scripts.sh

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

所以你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/8801780.html

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

发表评论

登录后才能评论

评论列表(0条)

保存