Linux signal()自定义信号及使用

singal()函数

  1. typedef void (*sighandler_t)(int);
  2. sighandler_t signal(int signum, sighandler_t handler);
  3. signal函数
  4. 作用1:站在应用程序的角度,注册一个信号处理函数
  5. 作用2:忽略信号,设置信号默认处理 信号的安装和回复
  6. 参数
  7. --signal是一个带signum和handler两个参数的函数,准备捕捉或屏蔽的信号由参数signum给出,接收到指定信号时将要调用的函数有handler给出
  8. --handler这个函数必须有一个int类型的参数(即接收到的信号代码),它本身的类型是void
  9. --handler也可以是下面两个特殊值:① SIG_IGN 屏蔽该信号 ② SIG_DFL 恢复默认行为

Linux终端下信号列表

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专用,进程超过资源限制的时候发送

自定义信号的使用


#include <stdio.h>
#include <unistd.h>
#include <signal.h>

static void sig_usr(int signo)  
{
	if (signo == SIGUSR1)
	{
		printf("received SIGUSR1!\n");
	}
	else if (signo == SIGUSR2)
	{
		printf("receive SIGUSR2!\n");
	}
}

int main()
{
	/*******************不明白在这里参数signo是怎么传到sig_usr中******************/
	if (signal(SIGUSR1, sig_usr) == SIG_ERR)
	{
		printf("signal1 error!\n");
	}
	
	if (signal(SIGUSR1, sig_usr) == SIG_ERR)
	{
		printf("signal2 error!\n");
	}
	
	for (;;)
	{
		pause();
	}

	return 0;
}

Linux终端下运行结果:

[root@localhost work1]# gcc 1.c -o 1
[root@localhost work1]# ./1 &
[1] 10826
[root@localhost work1]# kill -USR1 10826
[root@localhost work1]# received SIGUSR1!
kill -USR2 10826
[root@localhost work1]# 
[1]+  用户定义信号 2    ./1
[root@localhost work1]# 

 

  • 0
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Linux中的信号处理是通过信号机制实现的。当一个进程接收到一个信号时,它会根据事先定义好的处理方式来处理这个信号信号的处理方式包括终止进程、忽略信号、终止进程并生成core文件、停止进程和继续运行进程等不同的动作。 在Linux中,信号的处理是通过设置信号的处理函数来完成的。当一个信号到达时,内核会调用相应的处理函数来处理这个信号。可以通过系统提供的函数来设置自定义信号处理函数。 信号的发送可以通过多种方式,包括按键产生、终端按键产生、系统调用产生、软件条件产生和硬件异常产生等。不同的事件会触发不同的信号发送。例如,按下Ctrl+C会发送SIGINT信号,而按下Ctrl+Z会发送SIGTSTP信号。 对于进程来说,接收到信号后,不管正在执行什么代码,都会暂停运行,去处理信号。这种处理方式类似于硬件中断,被称为“软中断”。对于用户来说,由于信号的实现方式,信号的延迟时间非常短,几乎不可察觉。 总而言之,Linux中的信号处理是通过信号机制实现的,程序在接收到信号后会根据事先定义好的处理方式来处理这个信号。这种处理方式可以通过设置信号的处理函数来自定义信号的发送可以通过多种方式,不同的事件会触发不同的信号发送。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Linux信号signal)](https://blog.csdn.net/weixin_43408582/article/details/115523424)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值