有时候我们需要在程序中利用信号来控制程序行为,linux为我们提供了2个已经定义的信号SIGUSR1和SIGUSR2,一般的程序利用这2个信号已经能满足需要,不过我最近需要一些其他信号来避免覆盖原来的信号处理函数。
1 |
|
然后到系统里查了一下,MYSIG_MSG其实将其他的信号给覆盖了$kill -l
10) SIGUSR1 11) SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM
虽然SIGPIPE和SIGALRM在这个程序中没有用到,但是这并不是我想要的效果。
我发现在后面有
34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2
man 7 signal
页面同样也说明可以用 SIGRTMIN作为自定义信号。然后程序里就多了下面的代码:
1 |
结果出错了,但是并不是这个定义方式的问题。在我程序中有下面的代码:
1 | switch(signo){ |
// centos5.9 /usr/include/bits/signum.h
#define SIGRTMIN (__libc_current_sigrtmin ())
1 |
|
#define MYSIGRTMIN 34
#define MYSIG_MSG (MYSIGRTMIN + 1)
1 | 在找到系统定义的SIGRTMIN值之前,根据man 7 signal里面的说明: |
/* These are the hard limits of the kernel. These values should not be
used directly at user level. */
#define __SIGRTMIN 32
#define __SIGRTMAX (_NSIG - 1)
改成34之后就没有问题了。不过这个方法不太可靠,程序不应该直接用常量标识信号.