C语⾔:popen函数的⽤法
Linux中的popen()函数可以在程序中执⾏⼀个shell命令,并返回命令执⾏的结果。有两种操作模式,分别为读和写。在读模式中,程序中可以读取到命令的输出,其中有⼀个应⽤就是获取⽹络接⼝的参数。在写模式中,最常⽤的是创建⼀个新的⽂件或开启其他服务等。
头⽂件:
#include<stdio.h>
函数原型:
FILE *popen(const char*command,const char*type);
函数说明:
popen()函数通过创建⼀个管道,调⽤fork()产⽣⼀个⼦进程,执⾏⼀个shell以运⾏命令来开启⼀个进程。这个管道必须由pclose()函数关闭,⽽不是fclose()函数。pclose()函数关闭标准I/O流,等待命令执⾏结束,然后返回shell的终⽌状态。如果shell不能被执⾏,则pclose()返回的终⽌状态与shell已执⾏exit⼀样。
type参数只能是读或者写中的⼀种,得到的返回值(标准I/O流)也具有和type相应的只读或只写类型。如果type是"r"则⽂件指针连接到command的标准输出;如果type是"w"则⽂件指针连接到command的标准输⼊。
command参数是⼀个指向以NULL结束的shell命令字符串的指针。这⾏命令将被传到bin/sh并使⽤-c标志,shell将执⾏这个命令。
popen()的返回值是个标准I/O流,必须由pclose来终⽌。前⾯提到这个流是单向的(只能⽤于读或写)。向这个流写内容相当于写⼊该命令的标准输⼊,命令的标准输出和调⽤popen()的进程相同;与之相反的,从流中读数据相当于读取命令的标准输出,命令的标准输⼊和调⽤popen()的进程相同。
返回值:
如果调⽤fork()或pipe()失败,或者不能分配内存将返回NULL,否则返回标准I/O流。popen()没有为内存分配失败设置errno值。如果调⽤fork()或pipe()时出现错误,errno被设为相应的错误类型。如果type参数不合法,errno将返回EINVAL。
例⼦:
#include<stdlib.h>
#include<stdio.h>
#define BUF_SIZE 1024
char buf[BUF_SIZE];
int main(void)
{
shell命令属于什么语言FILE * p_file =NULL;
p_file =popen("ifconfig eth0","r");
if(!p_file){
fprintf(stderr,"Erro to popen");
}
while(fgets(buf, BUF_SIZE, p_file)!=NULL){
fprintf(stdout,"%s", buf);
}
pclose(p_file);
return0;
}
输出结果:
root@ye:/home/ye# gcc -Wall test_popen.c -o test_popen
root@ye:/home/ye# ./test_popen
eth0 Link encap:Ethernet HWaddr 00:16:3e:5f:31:4c
inet addr:172.20.110.214 Bcast:172.20.110.255 Mask:255.255.255.0 inet6 addr: fe80::216:3eff:fe5f:314c/64 Scope:Link
inet6 addr: 2001:250:3c02:74a:216:3eff:fe5f:314c/64 Scope:Global
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:683756 errors:0 dropped:2 overruns:0 frame:0
TX packets:8678 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:161460288 (161.4 MB) TX bytes:554406 (554.4 KB)
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论