Linux下Kill的用法

[ KILL ]功能描述:

用于向任何进程组或进程发送信号。

头文件用法:

#include <sys/types.h>#include <signal.h>int kill(pid_t pid, int sig);

参数: pid:可能选择有以下四种1. pid大于零时,pid是信号欲送往的进程的标识。2. pid等于零时,信号将送往所有与调用kill()的那个进程属同一个使用组的进程。3. pid等于-1时,信号将送往所有调用进程有权给其发送信号的进程,除了进程1(init)。4. pid小于-1时,信号将送往以-pid为组标识的进程。

sig:准备发送的信号代码,,假如其值为零则没有任何信号送出,但是系统会执行错误检查,通常会利用sig值为零来检验某个进程是否仍在执行。

返回值说明: 成功执行时,返回0。失败返回-1,errno被设为以下的某个值 EINVAL:指定的信号码无效(参数 sig 不合法) EPERM;权限不够无法传送信号给指定进程 ESRCH:参数 pid 所指定的进程或进程组不存在#include <sys/wait.h>#include <sys/types.h>#include <stdio.h>#include <stdlib.h>#include <signal.h>int main( void ){ pid_t childpid; int status; int retval; childpid = fork(); if ( -1 == childpid ) { perror( “fork()” ); exit( EXIT_FAILURE ); } else if ( 0 == childpid ) { puts( “In child process” ); sleep( 100 );//让子进程睡眠,看看父进程的行为 exit(EXIT_SUCCESS); } else { if ( 0 == (waitpid( childpid, &status, WNOHANG ))) { retval = kill( childpid,SIGKILL ); if ( retval ) { puts( “kill failed.” ); perror( “kill” ); waitpid( childpid, &status, 0 ); } else { printf( “%d killed\n”, childpid ); } } } exit(EXIT_SUCCESS);}//-----------------[root@localhost src]# gcc killer.c[root@localhost src]# ./a.outIn child process4545 killed

在确信fork调用成功后,子进程睡眠100秒,然后退出。同时父进程在子进程上调用waitpid函数,但使用了WNOHANG选项,所以调用waitpid后立即返回。父进程接着杀死子进程,如果kill执行失败,返回-1,否这返回0。如果kill执行失败,父进程第二次调用waitpid,保证他在子进程退出后再停止执行。否则父进程显示一条成功消息后退出。

不畏不惧,不言不弃,冲破风雨的阻隔,黎明就在前方!

Linux下Kill的用法

相关文章:

你感兴趣的文章:

标签云: