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;
}

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

相关推荐
小糖学代码3 小时前
LLM系列:1.python入门:3.布尔型对象
linux·开发语言·python
shizhan_cloud3 小时前
Shell 函数的知识与实践
linux·运维
Deng8723473483 小时前
代码语法检查工具
linux·服务器·windows
霍夫曼5 小时前
UTC时间与本地时间转换问题
java·linux·服务器·前端·javascript
月熊6 小时前
在root无法通过登录界面进去时,通过原本的普通用户qiujian如何把它修改为自己指定的用户名
linux·运维·服务器
大江东去浪淘尽千古风流人物6 小时前
【DSP】向量化操作的误差来源分析及其经典解决方案
linux·运维·人工智能·算法·vr·dsp开发·mr
赖small强7 小时前
【Linux驱动开发】NOR Flash 技术原理与 Linux 系统应用全解析
linux·驱动开发·nor flash·芯片内执行
IT运维爱好者8 小时前
【Linux】LVM理论介绍、实战操作
linux·磁盘扩容·lvm
LEEE@FPGA8 小时前
ZYNQ MPSOC linux hello world
linux·运维·服务器
郝学胜-神的一滴8 小时前
Linux定时器编程:深入理解setitimer函数
linux·服务器·开发语言·c++·程序人生