时间与文件,信号的操作

简介:

时间与文件,信号的操作

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <signal.h>
#include <time.h>
void fun(int x)
{
 printf("hello world!\r\n");
 int i;
 FILE *f=fopen("a.txt","rw+");
 if(f==NULL)
{printf("file error\r\n");
  exit(-1);};
 for(i=0;i<10;i++)
 {
  time_t a=time(NULL); 
  printf("%s\r\n",ctime(&a));
  //功 能: 把日期和时间转换为字符串
  //用 法: char *ctime(const time_t *time);
  fprintf(f,"%s\r\n",ctime(&a));

  struct tm *gmt;
  gmt = gmtime(&a);
     printf("%d/%d/%d  %d:%d:%d %d\r\n",gmt->tm_year+1900,gmt->tm_mon+1,gmt->tm_mday ,gmt->tm_hour,gmt->tm_min,gmt->tm_sec,gmt->tm_wday+1);
     fprintf(f,"%d/%d/%d  %d:%d:%d %d\r\n\n",gmt->tm_year+1900,gmt->tm_mon+1,gmt->tm_mday ,gmt->tm_hour,gmt->tm_min,gmt->tm_sec,gmt->tm_wday+1);
  sleep(2);
 }
 fclose(f);
 exit(1);
}
int main()
{
 signal(SIGINT,fun);    
 while(1);
}



/*

表头文件#include<signal.h>
功 能:设置某一信号的对应动作
函数原型:void (*signal(int signum,void(* handler)(int)))(int);
或者:typedef void(*sig_t) ( int );
sig_t signal(int signum,sig_t handler);
参数说明:
第一个参数signum指明了所要处理的信号类型,它可以取除了SIGKILL和SIGSTOP外的任何一种信号。
第二个参数handler描述了与信号关联的动作,它可以取以下三种值:
(1)一个无返回值的函数地址
此函数必须在signal()被调用前申明,handler中为这个函数的名字。当接收到一个类型为sig的信号时,就执行handler 所指定的函数。这个函数应有如下形式的定义:
void func(int sig);
sig是传递给它的唯一参数。执行了signal()调用后,进程只要接收到类型为sig的信号,不管其正在执行程序的哪一部分,就立即执行func()函数。当func()函数执行结束后,控制权返回进程被中断的那一点继续执行。
(2)SIG_IGN
这个符号表示忽略该信号,执行了相应的signal()调用后,进程会忽略类型为sig的信号。
(3)SIG_DFL
这个符号表示恢复系统对信号的默认处理。
函数说明:
signal()会依参数signum 指定的信号编号来设置该信号的处理函数。当指定的信号到达时就会跳转到参数handler指定的函数执行。当一个信号的信号处理函数执行时,如果进程又接收到了该信号,该信号会自动被储存而不会中断信号处理函数的执行,直到信号处理函数执行完毕再重新调用相应的处理函数。但是如果在信号处理函数执行时进程收到了其它类型的信号,该函数的执行就会被中断。
返回值:返回先前的信号处理函数指针,如果有错误则返回SIG_ERR(-1)。
下面的情况可以产生Signal:

   按下CTRL+C产生SIGINT
   硬件中断,如除0,非法内存访问(SIGSEV)等等
   Kill函数可以对进程发送Signal
   Kill命令。实际上是对Kill函数的一个包装
   软件中断。如当Alarm Clock超时(SIGURG),当Reader中止之后又向管道写数据(SIGPIPE),等等

程序例:
This example installs a signal handler routine for SIGFPE,
catches an integer overflow condition, makes an adjustment
to AX register, and returns. This example program MAY cause
your computer to crash, and will produce runtime errors
depending on which memory model is used.

#pragma inline
#include <stdio.h>
#include <signal.h>
void Catcher(int sig, int type, int *reglist)
{
printf("Caught it!\n");
*(reglist + 8) = 3; // make return AX = 3 
}
int main(void)
{
signal(SIGFPE, Catcher);
asm mov ax,07FFFH 
// AX = 32767 
asm inc ax 

// cause overflow 
asm into 
// activate handler 
The handler set AX to 3 on return. If that hadn't happened,
there would have been another exception when the next 'into'
was executed after the 'dec' instruction. 
asm dec ax 
// no overflow now 
asm into 
// doesn't activate 
return 0;
}
2 Signals:
Signal

Description
SIGABRT

由调用abort函数产生,进程非正常退出
SIGALRM

用alarm函数设置的timer超时或setitimer函数设置的interval timer超时
SIGBUS

某种特定的硬件异常,通常由内存访问引起
SIGCANCEL

由Solaris Thread Library内部使用,通常不会使用
SIGCHLD

进程Terminate或Stop的时候,SIGCHLD会发送给它的父进程。缺省情况下该Signal会被忽略
SIGCONT

当被stop的进程恢复运行的时候,自动发送
SIGEMT

和实现相关的硬件异常
SIGFPE

数学相关的异常,如被0除,浮点溢出,等等
SIGFREEZE

Solaris专用,Hiberate或者Suspended时候发送
SIGHUP

发送给具有Terminal的Controlling Process,当terminal被disconnect时候发送
SIGILL

非法指令异常
SIGINFO

BSD signal。由Status Key产生,通常是CTRL+T。发送给所有Foreground Group的进程
SIGINT

由Interrupt Key产生,通常是CTRL+C或者DELETE。发送给所有ForeGround Group的进程
SIGIO

异步IO事件
SIGIOT

实现相关的硬件异常,一般对应SIGABRT
SIGKILL

无法处理和忽略。中止某个进程
SIGLWP

由Solaris Thread Libray内部使用
SIGPIPE

在reader中止之后写Pipe的时候发送
SIGPOLL

当某个事件发送给Pollable Device的时候发送
SIGPROF

Setitimer指定的Profiling Interval Timer所产生
SIGPWR

和系统相关。和UPS相关。
SIGQUIT

输入Quit Key的时候(CTRL+\)发送给所有Foreground Group的进程
SIGSEGV

非法内存访问
SIGSTKFLT

Linux专用,数学协处理器的栈异常
SIGSTOP

中止进程。无法处理和忽略。
SIGSYS

非法系统调用
SIGTERM

请求中止进程,kill命令缺省发送
SIGTHAW

Solaris专用,从Suspend恢复时候发送
SIGTRAP

实现相关的硬件异常。一般是调试异常
SIGTSTP

Suspend Key,一般是Ctrl+Z。发送给所有Foreground Group的进程
SIGTTIN

当Background Group的进程尝试读取Terminal的时候发送
SIGTTOU

当Background Group的进程尝试写Terminal的时候发送
SIGURG

当out-of-band data接收的时候可能发送
SIGUSR1

用户自定义signal 1
SIGUSR2

用户自定义signal 2
SIGVTALRM

setitimer函数设置的Virtual Interval Timer超时的时候
SIGWAITING

Solaris Thread Library内部实现专用
SIGWINCH

当Terminal的窗口大小改变的时候,发送给Foreground Group的所有进程
SIGXCPU

当CPU时间限制超时的时候
SIGXFSZ

进程超过文件大小限制
SIGXRES

Solaris专用,进程超过资源限制的时候发送

包含头文件:time.h
原型:struct tm *gmtime(long *clock);
功能:把日期和时间转换为格林威治(GMT)时间的函数。将参数timep 所指的time_t 结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果由结构tm返回。
结构tm的定义为
struct tm
{
int tm_sec;
int tm_min;
int tm_hour;
int tm_mday;
int tm_mon;
int tm_year;
int tm_wday;
int tm_yday;
int tm_isdst;
};
int tm_sec 代表目前秒数,正常范围为0-59,但允许至61秒
int tm_min 代表目前分数,范围0-59
int tm_hour 从午夜算起的时数,范围为0-23
int tm_mday 目前月份的日数,范围01-31
int tm_mon 代表目前月份,从一月算起,范围从0-11
int tm_year 从1900 年算起至今的年数
int tm_wday 一星期的日数,从星期一算起,范围为0-6
int tm_yday 从今年1月1日算起至今的天数,范围为0-365
int tm_isdst 日光节约时间的旗标
此函数返回的时间日期未经时区转换,而是UTC时间。
返回值 返回结构tm代表目前UTC 时间
编辑本段应用举例
#include "stdio.h"
#include "time.h"
#include "stdlib.h"
int main(void)
{
time_t t;
struct tm *gmt, *area;
tzset();  
t = time(NULL);
area = localtime(&t);
printf("Local time is: %s", asctime(area));
gmt = gmtime(&t);
printf("GMT is: %s", asctime(gmt));
return 0;
}

*/


本文转自陈仲阳0 51CTO博客,原文链接:http://blog.51cto.com/wolfword/1225008

相关文章
|
7月前
|
消息中间件 NoSQL Linux
Linux进程信号【信号保存】
Linux进程信号【信号保存】
77 0
|
Linux 调度
按键消抖的两种方法--中断延迟工作与定时器
按键消抖的两种方法--中断延迟工作与定时器
668 0
|
2月前
定时器 在某个时间到达之后,执行指定的任务
本文介绍了两种实现定时器的方法:基于优先级队列(堆)和基于时间轮,以在指定时间到达后执行特定任务。
35 0
定时器 在某个时间到达之后,执行指定的任务
|
2月前
|
数据采集 传感器
定时中断基本结构
【10月更文挑战第21天】定时中断是在微控制器或计算机系统中,按预设时间间隔自动触发中断请求的机制。它由定时器硬件模块(含计数器、时钟源、控制寄存器)、中断控制器(处理中断请求、设置优先级、中断屏蔽)和中断服务程序(保存现场、执行任务、恢复现场)组成,实现定时任务的精确执行。
|
5月前
|
监控 数据处理
在使用LabVIEW控制多个串口设备进行数据读取时,读取时间过长
在使用LabVIEW控制多个串口设备进行数据读取时,读取时间过长
113 0
Linux驱动中断与时间篇——低分辨率定时器
Linux驱动中断与时间篇——低分辨率定时器
Linux驱动中断与时间篇——高精度定时器hrtimer
Linux驱动中断与时间篇——高精度定时器hrtimer
|
Windows
连续时间系统的冲激响应和零状态响应
连续时间系统的冲激响应和零状态响应
233 0
|
存储
TIM定时中断(内含:1.TIM简介+2.定时器类型+3.基本定时器+4.通用定时器+5.高级定时器+6.定时中断基本结构+7.预分频器时序+8.计数器时序+9.计数器有/无预装+10.RCC时钟树)
TIM定时中断(内含:1.TIM简介+2.定时器类型+3.基本定时器+4.通用定时器+5.高级定时器+6.定时中断基本结构+7.预分频器时序+8.计数器时序+9.计数器有/无预装+10.RCC时钟树)
485 0
TIM定时中断(内含:1.TIM简介+2.定时器类型+3.基本定时器+4.通用定时器+5.高级定时器+6.定时中断基本结构+7.预分频器时序+8.计数器时序+9.计数器有/无预装+10.RCC时钟树)
通过定时器T1查询方式控制LED1周期性闪烁(自由计数模式)
通过定时器T1查询方式控制LED1周期性闪烁(自由计数模式) 宏定义与函数声明 初始化 主函数
283 0