欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

C语言操作时间函数,实现定时执行某个任务小例子。

程序员文章站 2022-05-02 16:32:49
...

时间操作函数在实际项目开发中会经常用到,最近做项目也正好用到就正好顺便整理一下。

常用时间函数及举例

1、time函数

头文件:time.h
函数定义:time_t time (time_t *t)
说明:
	返回从197011日的UTC时间从000妙算起到现在所经过的秒数。

举例如下:

#include<stdio.h>
#include<time.h>
int main(){
	time_t timep;
	
	long seconds = time(&timep);
	printf("%ld\n",seconds);
	printf("%ld\n",timep);
	return 0;
}

输出:
C语言操作时间函数,实现定时执行某个任务小例子。有兴趣的同学可以计算下,从1970年1月1日0时0分0秒到现在经历了多少秒。

附:time_t 一路追踪发现就是从long类型经过不断的typedef ,#define定义过来的。

2、ctime函数

定义:char *ctime(const time_t *timep);
说明:将参数所指的time_t结构中的信息转换成真实世界的时间日期表示方法,然后将结果以字符串形式返回。注意这个是本地时间。

举例如下:

#include <stdio.h>
#include<time.h>
int main(void) {
	time_t timep;
	
	time(&timep);
	printf("%s\n",ctime(&timep));
	return 0;
}

输出:
C语言操作时间函数,实现定时执行某个任务小例子。

3、gettime函数

定义:struct tm *gmtime(const time_t *timep);
说明:将参数timep所指的time_t结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果由结构tm返回。此函数返回的时间日期未经时区转换,而是UTC时间。

struct tm结构的定:

struct tm{
	int tm_sec;/*秒数*/
	int tm_min; /*分钟*/
	int tm_hour;/*小时*/
	int tm_mday;/*日期*/
	int tm_mon; /*月份*/
	int tm_year; /*从1990年算起至今的年数*/
	int tm_wday; /*星期*/
	int tm_yday; /*从今年1月1日算起至今的天数*/
	int tm_isdst; /*日光节约时间的旗标*/
};

举例如下:

#include <stdio.h>
#include<time.h>
 
int main(void) {
	char *wday[] = {"Sun","Mon","Tue","Wed","Thu","Fri","Sat"};
	
	time_t timep;
	struct tm *p;
	
	time(&timep);
	p = gmtime(&timep);
	printf("%d/%d/%d ",(1900+p->tm_year),(1+p->tm_mon),p->tm_mday);
	printf("%s %d:%d:%d\n",wday[p->tm_wday],p->tm_hour,p->tm_min,p->tm_sec);
	return 0;
}

输出:
C语言操作时间函数,实现定时执行某个任务小例子。

4、 asctime函数

定义:
char *asctime(const struct tm *timeptr);
说明:
	将参数timeptr所指的struct tm结构中的信息转换成真实时间所使用的时间日期表示方法,结果以字符串形态返回。与ctime()函数不同之处在于传入的参数是不同的结构。
返回值:
	返回的也是UTC时间。

举例如下:

#include <stdio.h>
#include <stdlib.h>
#include<time.h>
int main(void) {
	time_t timep;
	
	time(&timep);
	printf("%s\n",asctime(gmtime(&timep)));
	return EXIT_SUCCESS;
}

输出:
C语言操作时间函数,实现定时执行某个任务小例子。

5、 localhost函数

struct tm *localhost(const time_t *timep);
取得当地目前的时间和日期

举例如下:

#include <stdio.h>
#include <stdlib.h>
#include<time.h>
 
int main(void) {
	char *wday[] = {"Sun","Mon","Tue","Wed","Thu","Fri","Sat"};
	time_t timep;
	struct tm *p;
	
	time(&timep);
	p = localtime(&timep);
	printf("%d/%d/%d ",(1900+p->tm_year),(1+p->tm_mon),p->tm_mday);
	printf("%s %d:%d:%d\n",wday[p->tm_wday],p->tm_hour,p->tm_min,p->tm_sec);
	return EXIT_SUCCESS;
}

输出:
C语言操作时间函数,实现定时执行某个任务小例子。

6、mktime函数

定义:time_t mktime(struct tm *timeptr);
说明:
	用来将参数timeptr所指的tm结构数据转换成从197011日的UTC时间从000妙算起到现在所经过的秒数。

举例如下:

#include <stdio.h>
#include <stdlib.h>
#include<time.h>
 
int main(void) {
	time_t timep;
	struct tm *p;
	
	time(&timep);
	printf("time():%ld\n",timep);
	p = localtime(&timep);
	timep = mktime(p);
	printf("time()->localtime()->mktime():%ld\n",timep);
	return EXIT_SUCCESS;
}

输出:
C语言操作时间函数,实现定时执行某个任务小例子。

7、 gettimeofday函数

定义:
int gettimeofday(struct timeval *tv,struct timezone *tz);
说明:
	把目前的时间由tv所指的结构返回,当地时区信息则放到有tz所指的结构中,

结构体timeval 定义如下:

struct timeval{
	long tv_sec; /*秒*/
	long tv_usec; /*微秒*/
};

结构体timezone定义如下:

struct timezone{
	int tz_minuteswest; /*和greenwich时间差了多少分钟*/
	int tz_dsttime; /*日光节约时间的状态*/
}

举例如下:

#include <stdio.h>
#include <stdlib.h>
#include<time.h>
#include<sys/time.h>
 
int main(void) {
struct timeval tv;
struct timezone tz;
gettimeofday(&tv,&tz);
printf("tv_sec :%d\n",tv.tv_sec);
printf("tv_usec: %d\n",tv.tv_usec);
printf("tz_minuteswest:%d\n",tz.tz_minuteswest);
printf("tz_dsttime:%d\n",tz.tz_dsttime);
return EXIT_SUCCESS;
}

输出:
C语言操作时间函数,实现定时执行某个任务小例子。

综合实验

现在我们利用这些时间函数,来实现一个定时执行某个任务得功能。

功能

  1. 程序运行时要记录当前日志文件的最后修改时间;
  2. 每个10秒钟就检查下log文件是否被修改,如果没有被修改就休眠10秒钟;
  3. 如果log文件被修改了,就将当前的日志文件拷贝成备份文件,备份文件名字加上当前时间;
  4. 通过curl发送给ftp服务器;
  5. 删除备份文件,重复步骤2。

程序流程图如下:

C语言操作时间函数,实现定时执行某个任务小例子。

函数功能介绍

init()

首先记录当前log文件时间,并记录到全局变量last_mtime中。

check_file_change()
读取文件最后修改时间,并和last_mtime进行比较,如果相同就返回0,不同就返回1.

file_name_add_time()
将当前的日志文件拷贝成备份文件,备份文件名字加上当前时间。

stat()​

得到对应文件的属性信息,存放到struct stat结构体变量中。

运行截图:

第一步:
C语言操作时间函数,实现定时执行某个任务小例子。
因为log文件没有被修改过,所以程序不会上传。

第二步:
手动输入字符串 yikoulinux 到日志文件 t.log中。
C语言操作时间函数,实现定时执行某个任务小例子。第三步:
因为文件发生了改变,所以打印“file updated”,同时可以看到curl上传文件的log信息。
C语言操作时间函数,实现定时执行某个任务小例子。以下是FTP服务器的根目录,可以看到,上传的日志文件:t-2020-7-26-1-19-45.log
C语言操作时间函数,实现定时执行某个任务小例子。

【补充】

  1. 配置信息,直接在代码中写死,通常应该从配置文件中读取,为方便读者阅读,本代码没有增加该功能;
  2. FTP服务器搭建,本文没有说明,相关文件比较多,大家可以自行搜索,一口君用的是File zilla;
    C语言操作时间函数,实现定时执行某个任务小例子。
  3. 通常这种需要长时间运行的程序,需要设置成守护进程,本文没有添加相应功能,读者可以自行搜索。如果强烈要求可以单开一篇详细介绍。
  4. 代码中time的管理函数,请读者自行搜索相关文章。
  5. curl也提供了相关的函数库curl.lib,如果要实现更灵活的功能可以使用对应的api。
  6. 之所以先把文件拷贝成备份文件,主要是考虑其他模块随时可能修改日志文件,起到一定保护作用。

代码如下

代码如下:

/***************************************************
           Copyright (C)  公众号: 一口linux  
***************************************************/
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <time.h>
 
typedef struct stat ST;
unsigned long last_mtime;

/*用户名密码暂时写死,实际应该保存在配置文件*/
char name[32]="user";
char pass[32] ="123456";
char ip[32]     ="192.168.43.117";
char filename[32]="t.log";
char dstfile[256]  ={0};

int init(void)
{
	//准备结构体
	ST status;
	
	//调用stat函数
	int res = stat(filename,&status);
	if(-1 == res)
	{
		perror("error:open file fail\n");
		return 0;
	}
	last_mtime = status.st_mtime;
	printf("init time:%s \n",ctime(&last_mtime));
	return 1;
}
	
int  check_file_change(void)
{
	//准备结构体
	ST status;
	
	//调用stat函数
	int res = stat(filename,&status);
	if(-1 == res)
	{
		perror("error:open file fail\n");
		return 0;
	}
//	printf("old:%s new:%s",ctime(&last_mtime),ctime(&status.st_mtime));
	if(last_mtime == status.st_mtime)
	{
		printf("file not change\n");
		return 0;
	}else{
		printf("file updated\n");	
		last_mtime = status.st_mtime;
		return 1;
	}

}
void file_name_add_time(void)
{
	ST status;
	time_t t; 	
	struct tm *tblock;	
	char cmd[1024]={0};
		
	t = time(NULL);
	tblock = localtime(&t);
	
	sprintf(dstfile,"t-%d-%d-%d-%d-%d-%d.log",
		tblock->tm_year+1900,
		tblock->tm_mon,
		tblock->tm_mday,
		tblock->tm_hour,
		tblock->tm_min,
		tblock->tm_sec);
	sprintf(cmd,"cp %s %s",filename,dstfile);
//	printf("cdm=%s\n",cmd);
	system(cmd);
}
int main(void)
{

	char cmd[1024]={0};

	init();
	while(1)
	{	
		if(check_file_change() == 1)
		{
			file_name_add_time();
			sprintf(cmd,"curl -u %s:%s ftp://%s/ -T %s",name,pass,ip,dstfile);
	//		printf("cdm=%s\n",cmd);
			system(cmd);
			unlink(dstfile);
		}
		sleep(10);	
	}
}

想和博主交流,请关注公众号「一口Linux」

相关标签: linux timestamp