在Unix系統中利用程序實現Kill命令
在正常情況下,一般先通過 Unix 系統的 ps命令,找到相關進程的進程號(pid),然后用 kill 9 pid 終止這些進程。這些操作對計算機專業人員很簡單,但對業務人員來說,卻是比較復雜的操作。如果能利用一段程序,業務人員只需要輸入終端號,即可殺死該終端的所有進程并重新激活,就可以簡化這種操作,提高工作效率。本文簡單介紹這種程序的實現方法。 程序的功能是根據終端號殺死進程并激活終端,操作上只要在另一臺終端上執行 killtty ttyname即可,其中ttyname 是需要激活的終端號。程序的實現原理是根據輸入的終端號,找到該終端運行的所有進程的進程號,并把這些進程號寫入文件。然后由大到小依次讀出所有的進程號,并執行Unix的系統命令 kill(pid,SIGKILL),將該進程殺死。程序的源代碼如下: #include<stdio.h> #include<sys/types.h> #include<signal.h> main(argc,argv) int argc; char *argv[]; { FILE *fp; char fname[50],pscmd[50],ttyname[10]; if(argc< 2){ printf(“usage:%s /dev/ttyname|ttyname|name}n”,argv[0]); exit(0); } strcpy(fname,“/tmp/psout”); strcat(fname,argv[1]); if(!strncmp(argv[1],“/dev/”,5)){ strncpy(ttyname,argv[1]+5,9); } else if(!strncmp(argv[1],“tty”,3)) strcpy(ttyname,argv[1]); else{ strcpy(ttyname,“tty”); strcat(ttyname,argv[1]); } sprintf(pscmd,“ps -o 'pid=“-t %s>%s”,ttyname,fname); if(system(pscmd)<0){ exit(-1); } kill_pid(fname); } kill_pid(filename) char *filename; { FILE *fp; char ch,pid[10]; int *ipid; ipid=(int *)(malloc(sizeof(int))); if((fp=fopen(filename,“r”))==NULL){ exit(-1); } while(fgets(pid,20,fp)!=NULL){ *ipid=atoi(pid); ipid++; } fclose(fp); while(--ipid){ kill(*ipid,SIGKILL); } } 上述程序中有關Unix的系統調用問題,請參考有關的技術資料,這里不再贅述。該程序在SCO OpenServer 5.04下編譯通過,可直接在該系統中編譯運行。