一个小的Linux程序,一运行电脑就自动关机。(要求两个进程轮流打印1.2.3.4....)

#include
#include
#include
#include
#include

void f_sigact(int num)
{
static int f = 2;
// sleep(1);
printf("I am father.This is %d\n",f);
f += 2;
}

void c_sigact(int num)
{
int static c = 1;
// sleep(1);
printf("I am child.This is %d\n",c);
c+=2;
}

int main()
{
pid_t fpid,cpid;
struct sigaction fact,cact;
fact.sa_handler = f_sigact;
cact.sa_handler = c_sigact;
// sigemptyset(&fact.sa_mask);
// sigaddset(&fact.sa_mask,SIGUSR2);
fact.sa_flags = 0;
// sigaction(SIGUSR1,&fact,NULL);
// sigemptyset(&cact.sa_mask);
sigaddset(&cact.sa_mask,SIGUSR1);

cact.sa_flags = 0;
sigaction(SIGUSR2,&cact,NULL);

fpid = fork();
if(fpid < 0){
    perror("fork");
    exit(1);
}
int m = 5;
while(1){
    if(fpid > 0){
        kill(fpid,SIGUSR2);
//      sleep(1);
        }
    else{
        cpid = getppid();
        kill(cpid,SIGUSR1);
//      sleep(1);
    }
    sleep(3);
}

return 0;

}

2个回答

#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
void f_sigact(int num)
{
        static int f = 2;
        // sleep(1);
        printf("I am father.This is %d\n",f);
        f += 2;
}
void c_sigact(int num)
{
        int static c = 1;
        // sleep(1);
        printf("I am child .This is %d\n",c);
        c+=2;
}
int main()
{
        pid_t fpid,cpid;
        struct sigaction fact,cact;
        struct sigaction ofact,ocact;
        fact.sa_handler = f_sigact;
        cact.sa_handler = c_sigact;
        // sigemptyset(&fact.sa_mask);
        // sigaddset(&fact.sa_mask,SIGUSR2);
        fact.sa_flags = 0;
        cact.sa_flags = 0;
        // sigaction(SIGUSR1,&fact,NULL);
        // sigemptyset(&cact.sa_mask);
        sigaddset(&cact.sa_mask,SIGUSR1);
        sigaddset(&fact.sa_mask,SIGUSR2);
        //sigaction(SIGUSR2,&cact,NULL);
        cpid = fork();
        if(cpid < 0){
                perror("fork");
                        exit(1);
        }
        else if (cpid==0){
                //it's a child
                sigaction(SIGUSR1,&cact,&ocact);
        }
        else{
                //it;s the parent
                sigaction(SIGUSR2,&fact,&ofact);
        }

        int m = 5;
        sleep(1);
        while(1){
                if (cpid>0)
                {
                        fpid = getpid();
                        kill(cpid,SIGUSR1);
                        sleep(1);
                        kill(fpid,SIGUSR2);
                        sleep(1);
                }
                        sleep(3);
        }

        return 0;
}

u013015654
coder_jacky 回复yanjing555: 对不起,看错了!囧
5 年多之前 回复
u013015654
coder_jacky 第二各kill中,fpid没有值吧?
5 年多之前 回复
gamefinity
知常曰明 回复gamefinity: 前面错了。我改的一个是分主进程和子进程设置sigaction,另外一个是在while(1)前加了一个延时。我试了不加延时的话子进程的信号收不到。
5 年多之前 回复
gamefinity
知常曰明 回复yanjing555: 我觉得问题最大的是循环那块。你的fpid是fork的返回值,也就是说,在主进程里,这个值是子进程的id,所以if的上半部分没问题。在子进程里是0
5 年多之前 回复
u013015654
coder_jacky 大神,我写的那个问题在哪呢?为什么在子进程中发送信号不行呢?
5 年多之前 回复

太感谢了~~昨晚想了好长时间!

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐