Linux进程——system函数、popen函数

system函数(执行shell 命令)

头文件

cs 复制代码
#include <stdlib.h>

函数定义

cs 复制代码
int system(const char * string);

函数说明

system()会调用fork()产生子进程,由子进程来调用/bin/sh-c string来执行参数string字符串所代表的命令,此命令执行完后随即返回原调用的进程。在调用system()期间SIGCHLD 信号会被暂时搁置,SIGINT和SIGQUIT 信号则会被忽略。

返回值

如果system()调用/bin/sh时失败则返回127,其他失败原因返回-1。若参数string为空指针(NULL),则返回非零值。如果 system()调用成功则最后会返回执行shell命令后的返回值,但是此返回值也有可能为system()调用/bin/sh失败所返回的127,因此最好能再检查errno 来确认执行成功。

附加说明

在编写具有SUID/SGID权限的程序时请勿使用system(),system()会继承环境变量,通过环境变量可能会造成系统安全的问题。

代码示例

cs 复制代码
#include<stdio.h>
#include <unistd.h>
int main()
{
        int a= 0;
        int fork_r=0;
        while(1)
	    {                
		        printf("please input a num\n");
                scanf("%d",&a);
                if(a==1)
		        {
                	fork_r=fork();
                    if(fork_r==0)
			        {
//             	 		execl("./changeData","changeData",NULL,NULL);
				        system("./changeData");//直接将可执行文件字符串输入便会执行指令
                    }
                }
		        else
		        {
                        printf("no change success\n");
                }
        }
        return 0;
}

直接调用changeData可执行文件并执行,成功将数据修改。

popen函数(执行shell 命令,同时可以获取运行的输出结果)

头文件

cs 复制代码
#include <stdio.h>

函数定义

cs 复制代码
FILE popen( const char* command, const char* mode )

函数说明

command: 是一个指向以 NULL 结束的 shell 命令字符串的指针。这行命令将被传到 bin/sh 并使用 -c 标志,shell 将执行这个命令。
type: 只能是读或者写中的一种。
如果 type 是 "r" 则文件指针连接到 command 的标准输出;
如果 type 是 "w" 则文件指针连接到 command 的标准输入。

依照此type值,popen()会建立管道连到子进程的标准输出设备或标准输入设备,然后返回一个文件指针,随后进程便可利用此文件指针来读取子进程的输出设备或是写入到子进程的标准输入设备中。

返回值

成功,则返回一个读或者打开文件的指针
失败,返回NULL,具体错误要根据errno判断

附加说明

popen函数建立的管道连到子进程的输出或输入设备即读写操作需要调用到前面学过的fread(读)和fwrite(写)

cs 复制代码
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
size_t fwrite(const void *ptr, size_t size, size_t nmemb,FILE *stream);

popen() 函数用于创建一个管道:其内部实现为调用 fork 产生一个子进程,执行一个 shell 以运行命令来开启一个进程,而这个进程必须由 pclose() 函数关闭。stream是popen返回的文件指针。

cs 复制代码
int pclose(FILE *stream);

代码示例

cs 复制代码
#include <stdio.h>

int main()
{
	char result[512]={0};
	FILE *fp = NULL;
	int n_read = 0;

	fp = popen("ps","r");//r为输出(读取)
	n_read = fread(result,1,128,fp);//每次读一个字节,总共读512次(小于512则会读真实值,大于512会报错),将fp的内容读取到result
	printf("read %d byte to result,result = %s\n",n_read,result);
	pclose(fp);	

	return 0;
}

成功获取运行输出结果并将其打印出来。

相关推荐
酉鬼女又兒1 小时前
零基础入门Linux指南:每天一个Linux命令_pwd
linux·运维·服务器
云飞云共享云桌面1 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
zl_dfq1 小时前
Linux 之 【多线程】(pthread_xxx、轻量级进程、原生线程库、线程ID、__thread、线程栈、线程与信号、线程与程序替换)
linux
choke2331 小时前
Python 基础语法精讲:数据类型、运算符与输入输出
java·linux·服务器
AZ996ZA1 小时前
自学linux的第二十一天【DHCP 服务从入门到实战】
linux·运维·服务器·php
_OP_CHEN1 小时前
【Linux系统编程】(二十八)深入 ELF 文件原理:从目标文件到程序加载的完整揭秘
linux·操作系统·编译·c/c++·目标文件·elf文件
Fleshy数模2 小时前
MySQL 表创建全攻略:Navicat 图形化与 Xshell 命令行双模式实践
linux·mysql
神梦流2 小时前
GE 引擎的非标准数据流处理:稀疏张量与自定义算子在图优化中的语义保持
linux·运维·服务器
.小墨迹3 小时前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
Lsir10110_3 小时前
【Linux】中断 —— 操作系统的运行基石
linux·运维·嵌入式硬件