Chinaunix首页 | 论坛 | 博客
  • 博客访问: 857404
  • 博文数量: 254
  • 博客积分: 5350
  • 博客等级: 大校
  • 技术积分: 2045
  • 用 户 组: 普通用户
  • 注册时间: 2008-06-27 13:27
文章分类

全部博文(254)

文章存档

2015年(1)

2014年(9)

2013年(17)

2012年(30)

2011年(150)

2010年(17)

2009年(28)

2008年(2)

分类: C/C++

2011-10-13 15:55:46

发送信号的kill和raise函数

 
int kill(pid_t pid, int sig);

int raise(int sig);

 


kill()发送信号给指定进程,raise()发送信号给进程本身。对kill()的pid,有如下描述:

 


pid > 0 将信号发送给ID为pid的进程

pid == 0 将信号发送给与发送进程属于同个进程组的所有进程

pid < 0 将信号发送给进程组ID等于pid绝对值的所有进程

pid == -1 将信号发送给该进程有权限发送的系统里的所有进程

 


所有信号的发送都要先经过权限检查,如果进程没有相应发送的权限,kill()会出错返回,并把errno设为EPERM。但也有一个例外,对SIGCONT,进程可以将它发送给当前会话的所有进程。

 

#include
#include
#include
#include
#include

int main()
{
 pid_t pid;
 int ret;
 if((pid=fork())<0){
  perror("fork");
  exit(1);
 }
 if(pid == 0){
  raise(SIGSTOP);
  exit(0);
 }
 else{
  printf("pid=%d\n",pid);
  if((waitpid(pid,NULL,WNOHANG))==0) 

  {
   if((ret=kill(pid,SIGKILL))==0)
    printf("kill %d\n",pid);
   else{
    perror("kill");
   }
  }
 }
}

 

 

waitpid(父进程等待子进程中断或结束)

  表头文件

  #include

  #include

  定义函数 pid_t waitpid(pid_t pid,int * status,int options);

  函数说明

  waitpid()会暂时停止目前进程的执行,直到有信号来到或子进程

  结束。如果在调用 waitpid()时子进程已经结束,则 waitpid()会立即

  返回子进程结束状态值。 子进程的结束状态值会由参数 status 返回,

  而子进程的进程识别码也会一起返回。如果不在意结束状态值,则

  参数 status 可以设成 NULL。参数 pid 为欲等待的子进程识别码,

  其他数值意义如下:

  pid<-1 等待进程组识别码为 pid 绝对值的任何子进程。

  pid=-1 等待任何子进程,相当于 wait()。

  pid=0 等待进程组识别码与目前进程相同的任何子进程。

  pid>0 等待任何子进程识别码为 pid 的子进程。

  参数options提供了一些额外的选项来控制waitpid,参数 option 可以为 0 或可以用"|"运算符把它们连接起来使用,比如:

  

ret=waitpid(-1,NULL,WNOHANG | WUNTRACED);
如果我们不想使用它们,也可以把options设为0,如:
ret=waitpid(-1,NULL,0); 
 WNOHANG 如果没有任何已经结束的子进程则马上返回, 不予以等待。

 

  WUNTRACED 如果子进程进入暂停执行情况则马上返回,但结束状态不予以理会。

  子进程的结束状态返回后存于 status,底下有几个宏可判别结束情况:

  WIFEXITED(status)如果子进程正常结束则为非 0 值。

  WEXITSTATUS(status)取得子进程 exit()返回的结束代码,一般会先用 WIFEXITED 来判断是否正常结束才能使用此宏。

  WIFSIGNALED(status)如果子进程是因为信号而结束则此宏值为真

  WTERMSIG(status) 取得子进程因信号而中止的信号代码,一般会先用 WIFSIGNALED 来判断后才使用此宏。

  WIFSTOPPED(status) 如果子进程处于暂停执行情况则此宏值为真。一般只有使用 WUNTRACED 时才会有此情况。

  WSTOPSIG(status) 取得引发子进程暂停的信号代码,一般会先用 WIFSTOPPED 来判断后才使用此宏。

  如果执行成功则返回子进程识别码(PID) ,如果有错误发生则返回

 


 

 

 

产生时钟信号SIGALRM的alarm函数

 


unsigned int alarm(unsigned int seconds);

 


alarm()函数可设置一个计时器,计时器超时就产生SIGALRM信号。由于每个进程只能有一个SIGALRM处理程序,所以只能为一个进程设置一个 计时器,所以alarm()和setitimer()会共享同一个SIGALRM信号和该信号的处理函数。也就是说,alarm()和 setitimer()彼此会互相影响。调用alarm(),会使先前设置的计时器失效,并把没有超时的时间作为当前alarm的返回值。如先前设置的时 钟为100秒,当前调用alarm()时才经过30秒,剩余的70秒就作为alarm()的返回值,并用alarm()中指定的秒数重新设置计时器。如果 seconds为0,则会取消先前设置的计时器,并将其余留值作为alarm()的返回值。

 


等待信号的pause函数

 


int pause(void);

 


pause()会使当前进程挂起,直到捕捉到一个信号,对指定为忽略的信号,pause()不会返回。只有执行了一个信号处理函数,并从其返回,puase()才返回-1,并将errno设为EINTR。

 

#include
#include
#include
void my_func(int sign_no)
{
 if(sign_no==SIGINT)
  printf("I have get SIGINT\n");
 else if(sign_no==SIGQUIT)
  printf("I have get SIGQUIT\n");
}
int main()
{
 printf("Waiting for signal SIGINT or SIGQUIT \n ");
 signal(SIGINT, my_func);
 signal(SIGQUIT, my_func);
 pause();
 exit(0);
}

阅读(486) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~