3

我有这个代码

static void sigXCPU(int pTmp){
  cout<<" .... ";
}

.....
pid_t vPid=fork(); 
  int vStat;   

  switch(vPid){
  case -1: perror("fork");
    exit(1);
  case 0:
    //limit on data
    struct rlimit vLimD;
    vLimD.rlim_cur = 100000; 
    vLimD.rlim_max =  1000000; 
    setrlimit(RLIMIT_DATA, &vLimD);
    //limit on cpu time
    struct rlimit vLimCPU;
    vLimCPU.rlim_cur = 1;
    vLimCPU.rlim_max = 1;

    execl("./p1","",NULL);    
    if(signal(SIGXCPU,sigXCPU)==SIG_ERR);
    break;
  default: 
    while(wait(&vStat)!=vPid);
    break;}

p1 的代码是

int main(){
  sleep(10);
return 0;}

为什么孩子忽略SIGXCPU?代码是在FreeBsd 8.0 amd64下用gcc编译的。

4

1 回答 1

3

child afterexecl中的代码永远不会执行,因为当前进程映像被替换为p1.

即使您将信号处理程序放在 之前execl,它也会被覆盖,因为信号处理在 exec 之后被重置为其默认值。毕竟,您的处理程序函数将不再存在于新的进程映像中。

最后,要设置信号处理程序,请避免使用signal和使用sigaction

于 2012-05-01T18:31:33.990 回答