先看程序再看理论:
/*
============================================================================
Name : testc.c
Author : xuejx
Version :
Copyright : Your copyright notice
Description : 模拟linux signal 函数
============================================================================
*/
#include <stdio.h>
#include <stdlib.h>
void ( * signal ( char * msg ,void (* handler)(char * s) ) ) (char * ){
handler(msg); //调用信号处理函数
return handler;//返回信号处理函数
}
void testHanler(char * s){ //一个信号处理函数实例
printf("----%s/n",s);
}
typedef void (* HANDLER)(char * ); //定义函数指针类型
int main(void){
HANDLER oldHandler= signal("安装信号!",testHanler);//模拟信号安装
oldHandler("返回的信号处理函数!"); //
return 0;
}
运行结果:
----安装信号!
----返回的信号处理函数!
C语言中的抽象函数定义也就是使用了函数指针,这里用signal函数解释一下抽象函数定义的含义和规则。
signal函数定义为:
void ( * signal (int signum , void (*handler)(int) ) )(int);
可以这样定义
typedef void(* handler) (int)
handler signal(int signum,handler)
通俗的说:
signal 是一个函数 这个函数有两个参数一个为int signum ,一个是一个函数指针 handler,handler 是一个有一个int参数 且返回值为void的函数指针。 signal 返回一个函数指针 void (*)(int)
即signal函数 给signum 这个信号安装信号处理函数 handler ,如果安装成功则返回 处理函数指针
作为函数参数的函数指针有一个专门的名称叫做回调,你可以把任意满足回调函数参数特征标的函数地址作为参数传给signal。
在这里因为signal对于sig参数可以指定用户自定义的信号处理函数,所以你可以把你要处理的这个sig的函数地址作为参数传给signal,那么系统接收到对应sig的时候就会通过你传进去的地址调用你的这个函数。