bash は、`execve()` がシグナル処理を処理する方法にさらに変更を加えずに `execve()` を呼び出しますか?

bash は、`execve()` がシグナル処理を処理する方法にさらに変更を加えずに `execve()` を呼び出しますか?

Bashのマニュアルにはこう書いてある

組み込みコマンドやシェル関数以外の単純なコマンドを実行する場合、シェルによってキャッチされたトラップは次のようにリセットされます。シェルの親から継承された値シェルによって無視されたトラップは無視されます

execve() マニュアルページ言う

execve(2)の実行中、処理されたシグナルの処理は次のようにリセットされる。デフォルト; 無視された信号の処理は変更されません。"

「デフォルト」と「シェルの親から継承された値」は同じですか?

bash は、シグナル処理の処理execve()方法にさらなる変更を加えずに呼び出しますか?execve()

ありがとう。

答え1

いいえ、「デフォルト」と「シェルの親から継承された値」は同じではありません。execveの場合、「デフォルト」は を指しSIG_DFL、指定されたデフォルトのアクションを引き起こします。man 7 signalbash の場合、「シェルの親から継承された値」とは、まさにその通りの意味です。つまり、そのようなシグナルがSIG_IGN親によって無視された場合 ( )、その子でも無視されます。

ここで何が起こっているかを理解するための鍵は、「handled」という単語です。これは、またはとは異なるカスタム シグナル ハンドラー関数を指しますSIG_DFLSIG_IGN新しいプロセスには古いプロセスが使用していたシグナル ハンドラー関数がないため、execve によってリセットする必要があります。

execve マニュアルページの新しいバージョンでは、Linux の他の部分で使用される用語に合わせて、「処理された」シグナルを「キャッチされた」シグナルと呼んでいることに注意してください。これは、デフォルト シグナルと無視されるシグナルの両方とは異なります。

シンプルバージョン: bash または bash の親のいずれかに としてマークされたシグナルがある場合SIG_IGN、そのシグナルは新しい子にもありますSIG_IGN。そうでない場合は、SIG_DFL新しい子に存在します。bash またはその親からのハンドラーは新しい子には存在しないため、新しい子のハンドラーになることはできません。

関連情報