子プロセス - 親プロセスが終了するとイベントを受け取ります。

子プロセス - 親プロセスが終了するとイベントを受け取ります。

別のサブプロセスがあります。親プロセスのpidを知っています。 MacOSとLinuxで親プロセスが終了したときに子プロセスからリッスンする方法はありますか?

親プロセスが終了したら、子プロセスからロックファイルを削除するために呼び出す必要があります。

ポーリングを必要としないソリューションを探しています。

waitid()可能だと聞きました。 MacOSでは、gccを使用してコンパイルされた小さなプログラムがありますが、コード255で終了します。唯一の推測は、waitid()が現在のプロセスの子プロセスではないプロセスでは機能しないためです。

#include <stdlib.h>
#include <sys/wait.h>
#include <stdio.h>

int main(int argc, char *argv[]) {
    pid_t pid = atoi(argv[1]);
    printf("pid = %jd\n", (intmax_t) pid);
    siginfo_t sig;
    return waitid(P_PID, pid, &sig, WEXITED|WNOWAIT);
}

答え1

MacOSでは、実際に私が探している動作があります。 (おそらくポーリングを使用しない可能性があります。)

https://github.com/brainopener/mac-pid-waiter

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/event.h>

int main(int argc, const char * argv[]) {

    pid_t pid;    
    if(argc!=2 || (pid=atoi(argv[1]))<=0)
    {
        fprintf(stderr,"USAGE\nwaiter pid\n");
        return 1;
    }

    int kq=kqueue();
    if (kq == -1) {
        fprintf(stderr,"kqueue returned -1.");
    return 1;
    }

    struct kevent ke;    
    EV_SET(&ke, pid, EVFILT_PROC, EV_ADD, NOTE_EXIT, 0, NULL);

    if (kevent(kq, &ke, 1, NULL, 0, NULL)<0) {
        fprintf(stderr,"kevent failed.");
    return 1;
    }


    for(;;) {
        memset(&ke,0,sizeof(struct kevent));
        if(kevent(kq, NULL, 0, &ke, 1, NULL)<0){
            fprintf(stderr,"kevent failed.");
        return 1;
        }

        if (ke.fflags & NOTE_EXIT)
        break;
    }

    return 0;
}

関連情報