popen和pclose实现判断某进程是否存在

概述:

用popen函数,然后用fgets函数读数据,检查输出结果.

这里需要注意的是popen和pclose函数结对使用。

标准I/O函数库提供了popen函数,它启动另外一个进程去执行一个shell命令行。这里我们称调用popen的进程为父进程,由popen启动的进程称为子进程。

popen函数还创建一个管道用于父子进程间通信。父进程要么从管道读信息,要么向管道写信息,至于是读还是写取决于父进程调用popen时传递的参数。


函数介绍:

FILE *popen(const char *command, const char *type);
int pclose(FILE *stream);

函数功能:popen()会调用fork()产生子进程,然后从子进程中调用/bin/sh -c来执行参数command的指令。
        参数type可使用“r”代表读取,“w”代表写入。
        依照此type值,popen()会建立管道连到子进程的标准输出设备或标准输入设备,然后返回一个文件指针。
        随后进程便可利用此文件指针来读取子进程的输出设备或是写入到子进程的标准输入设备中

函数功能:pclose()用来关闭由popen所建立的管道及文件指针。参数stream为先前由popen()所返回的文件指针
返回值:若成功返回shell的终止状态(也即子进程的终止状态),若出错返回-1,错误原因存于errno中

示例

#include<unistd.h>
#include<sys/types.h>
#include<sys/wait.h>
#include<stdio.h>
#include<stdlib.h>
#include<fcntl.h>
#include<limits.h>
#define BUFSZ 150

int main(int argc, char *argv[])
{
  FILE* fp;
  int count;
  char buf[BUFSZ];
  char command[150];
  sprintf(command, "ps -ef | grep **** | grep -v grep | wc -l" );
  if((fp = popen(command,"r")) == NULL)
    perror("popen");
  if( (fgets(buf,BUFSZ,fp))!= NULL )
  {
    count = atoi(buf);
    if(count == 0)
      printf("not found\n");
    else
      printf("process :tdv1 total is %d\n",count);
  }
  pclose(fp);
  return 0;
}

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值