Linux进程相关函数
system函数的使用
先看linux版system函数的源码:
代码:
#include
#include
#include
#include
int system(const char * cmdstring)
{
pid_t pid;
int status;
if(cmdstring == NULL){
return (1);
}
if((pid = fork())<0){
status = -1;
}
else if(pid == 0){
execl("/bin/sh", "sh", "-c", cmdstring, (char *)0);
-exit(127); //子进程正常执行则不会执行此语句
}
else{
while(waitpid(pid, &status, 0) < 0){
if(errno != EINTER){
status = -1;
break;
}
}
}
return status;
}
通过源码可以看出,在linux系统下,system函数是execl函数的封装版
文中的 "sh -c ps"
和我们所使用的"ps"
是完全等价的。system调用execl函数来执行相关指令
这为我们提供了极大的便利
#include <stdio.h>
#include <stdlib.h>
int main()
{
system("top");
printf("\n");
}
这样就可以直接执行top指令
我们运用一个测试文件
#include <stdio.h>
int main(int argc,char *argv[])
{
int i;
for(i=0;i<argc;i++){
printf("argv[%d]:%s\n",i,argv[i]);
}
return 0;
}
用system函数来执行它
#include <stdio.h>
#include <stdlib.h>
int main()
{
system("./test aa bb cc dd");
printf("\n");
}
效果如下:
argv[0]:./test
argv[1]:aa
argv[2]:bb
argv[3]:cc
argv[4]:dd
popen函数的使用
FILE * popen(conste char * command, const char * type);
type:可使用“r”或者"w",分别代表读取及写入,但由于popen是以创建管道的方式创建进程连接到子进程的标准输出设备或标准输入设备,因此其带有管道的一些特性,同一时刻只能定义为写或者读。
command:如其名,单纯是一个命令字符串指针。
返回值:文件指针,函数执行成功返回文件指针,否则返回NULL。
popen特点是会将读取到的内容放入一个文件缓冲区,需要时我们而已打印出来
#include <stdio.h>
//size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
int main()
{
char ret[1024];//文件缓冲区
FILE *fp;//文件流
fp = popen("ps -l","r");
int size = fread(ret,1,1024,fp);
printf("%d%s\n",size,ret);
}
效果如下: