通常,您可以使用 取消信号 15 的陷阱trap 15
。这将包括在当前 shell 开始忽略它时将忽略的信号重置回默认值。
但是,一些实验(在 macOS Sierra 10.12 上使用 Bash 3.2.57)表明,如果在进程启动时忽略信号(从父进程继承),那么您无法重置为默认处理 - 它继续被忽略。此外,像 trap ': do nothing' 15
随后trap 15
这样的尝试并不能完成这项工作。
我编写了一个名为iqon
(interrupt, quit on — 1989 年的第一个版本) 的 C 程序,以确保信号被随后执行的命令捕获(或忽略)。
iqon -s 15 -- bash processB.sh
这个主题作品的变化。
请注意,iqon
仅将信号 SIGTERM 设置为默认状态(无参数处理)的简单版本可能如下所示:
#include <signal.h>
#include <stdio.h>
#include <unistd.h>
int main(int argc, char **argv)
{
if (argc <= 1)
{
fprintf(stderr, "Usage: %s cmd [arg ...]", argv[0]);
return 1;
}
signal(SIGTERM, SIG_DFL);
execvp(argv[1], &argv[1]);
perror(argv[1]);
return 1;
}
显然,您可以毫不费力地将其变得更复杂。我的版本支持这样的帮助信息:
Usage: iqon [-dhV] [-s signal] [-i signal] cmd [args ...]
-d Set interrupt and quit to default
-h Print this help and exit
-i signal Ignore signal (number)
-s signal Set default for signal (number)
-V Print version information and exit
默认值(将中断和退出设置为默认行为)是其最初目的的遗留物——用于从忽略中断和退出信号的 4GL 创建的程序中运行程序。这也是名称的来源:i
nterrupt 和q
uit on
。