簡體   English   中英

Linux中使用sigaction的信號處理程序(C ++)

[英]Signal handler in Linux using sigaction (C++)

我正在嘗試使用自定義處理程序在多個進程之間發送SIGUSR1 / SIGUSR2信號,但是我的處理程序不起作用。 它不打印任何調試消息或任何東西。

在這里,我正在創建8個進程,並嘗試使用set_sigaction函數設置自定義處理程序:

int main(){
    pidArray = (int *)mmap(NULL, MMAP_SIZE, PROT_READ | PROT_WRITE,MAP_ANONYMOUS | MAP_SHARED, -1, 0);//Self pid
    pidArray2 = (int *)mmap(NULL, MMAP_SIZE, PROT_READ | PROT_WRITE,MAP_ANONYMOUS | MAP_SHARED, -1, 0);//Child pid
    counter = (int *)mmap(NULL, MMAP_SIZE2, PROT_READ | PROT_WRITE,MAP_ANONYMOUS | MAP_SHARED, -1, 0);
    counter[0]=0;
    counter[1]=0;
    pid_t pid, pid2;
    int counter = 1;
    pidArray[0]=getpid();
    pid = fork(); //1
    if(pid == 0){
        pid = fork(); //2
        if(pid != 0){
            pidArray[1]=getpid();
            pidArray2[1]=pid;
        }
        if(pid == 0){
            pid2 = getpid();
            pidArray[2]=pid2;
            pid=fork(); //4
            if(pid == 0){
                pidArray[4] = getpid();
                pid=fork(); //5
                if(pid==0){
                    pidArray[5] = getpid();
                    pidArray2[5] = 0;
                }
                else
                    pidArray2[4] = pid;
            }
        if(pid2 == getpid()){
            pid2 = fork(); //3
            if(pid2!=0){
                pid = setpgid(pid,pid2);
            }
            else{
                pidArray[3]=getpid();
                pid=fork(); //6
                if(pid==0){
                    pidArray[6]=getpid();
                    pid=fork(); //7
                    if(pid==0){
                        pidArray[7]=getpid();
                        pid=fork(); //8
                        if(pid!=0)
                            pidArray2[7]=pid;
                        else{
                            pidArray[8]=getpid();
                            pidArray2[8]=pidArray[1];
                        }

                    }
                    else
                        pidArray2[6]=pid;
                }
                else
                    pidArray2[3]=pid;
            }
        }        
        }
    }

    set_sigaction(SIGUSR1);

    sleep(5);

    if(getpid()==pidArray[1])
        kill(pidArray[0],SIGTERM);
    if(getpid()==pidArray[1]){
        send_signal(pidArray[1]);
    }
    sleep(100);
    return 0; 

這是set_sigaction函數:

static int set_sigaction(int signo) 
{ 
    struct sigaction sa; 
    memset(&sa, 0, sizeof(struct sigaction));
    sa.sa_sigaction = handler;
    sigemptyset(&sa.sa_mask);  
    sa.sa_flags = SA_SIGINFO;
    return sigaction(signo, &sa, NULL);
}

這是處理程序:

static void handler(int signo, siginfo_t* si, void* ucontext){
    int k;
    int i;
    pid_t pid = getpid();
    for(i=1;i<9;i++){
        if(pidArray[i]==pid)
            k=i;
    }
    time_t rawtime;
    time ( &rawtime );
    cout << k << " " << pid << " Got USR1 " << ctime (&rawtime) << "\n";
    send_signal(getpid());
}

我的send_signal函數給我此消息,這意味着它將SIGUSR1信號發送給第二個進程:

1 3156發送USR1 2017年6月22日星期四18:04:54

我在想問題是如何創建多個進程或如何設置處理程序。

send_signal做什么? 嘗試使用kill函數發送信號:

kill(pidArray [1],SIGUSR1)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM