常规变量、指针、数组别名
typedef signed char int8_t
固定大小的数据类型宏定义,一个字节八位typedef char *pChar
typedef char pChar[10]
函数声明
对于typedef void (*fp) (int);
,其中fp代表一个函数指针,可用于简化某些复杂函数的声明。
比如对于信号处理signal
函数,接受两个参数:
- 需要“被捕获”的特定signal的整数值,类型为int
- 指向用户提供函数的指针,类型为函数指针。其中用户函数返回值为void,参数一个为int
signal函数返回值为函数指针,类型和第二个参数相同。
signal函数常规声明如下,比较复杂,难以看懂:
void (*signal(int ,void(*)(int)))(int);
可以用typedef简化声明,一目了然:
typedef void (*sighandler_t)(int);//sighandler_t函数指针
//signal返回函数指针,接受两个参数int和函数指针
sighandler_t signal(int sig,sighandler_t handler);
题外话
通过man signal
查看发现linux不建议使用signal函数,用sigaction代替,可以让你更加细致地控制信号处理的行为
sigaction使用例程
#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <errno.h>
static void sig_usr(int signum){
if(signum == SIGUSR1){//默认处理:进程终止
printf("SIGUSR1 received\n");
}else if(signum == SIGUSR2){//默认处理:进程终止
printf("SIGUSR2 received\n");
}else{
printf("signal %d received\n", signum);
}
}
int main(void){
char buf[512];
int ret;
struct sigaction sa_usr;
sa_usr.sa_flags = 0;
sa_usr.sa_handler = sig_usr;//信号处理函数
sigaction(SIGUSR1, &sa_usr, NULL);
sigaction(SIGUSR2, &sa_usr, NULL);
printf("My PID is %d\n", getpid());
while(1){
ret = read(STDIN_FILENO, buf, 511);
if(ret == -1){
if(errno == EINTR)
printf("read is interrupted by signal\n");
}else{
buf[ret] = '\0';
printf("%d bytes read: %s\n",ret, buf);
}
}
return 0;
}
编译:gcc -o my_sigaction my_sigaction.c
运行:
./my_sigaction
- 在另一个终端发送
kill -USR1 pid
和kill -USR2 pid