exec族函数:
首先 ,先man exec 查看下exec函数原型
#include <unistd.h>
extern char **environ;
int execl(const char *path, const char *arg, ...);
int execlp(const char *file, const char *arg, ...);
int execle(const char *path, const char *arg,
..., char * const envp[]);
int execv(const char *path, char *const argv[]);
int execvp(const char *file, char *const argv[]);
int execvpe(const char *file, char *const argv[],
char *const envp[]);
我们可以看出来,前面都是exec开头,我们来分别说一下后面几个数字:
l代表的是list:命令行参数列表
p代表的是path:搜索file时的使用的path变量
v代表的是vector:使用命令行参数数组
接下来说一个后面的参数:
path:可执行文件的路径名
arg:可执行程序所带参数,第一个参数为可执行程序名,而结尾必须以NULL结尾
file:如果file中没有包含./ 也就是说没有在当前目录,就配置PATH变量。
结合来说:
int execl(const char *path, const char *arg, …):
函数作用就是在当前目录下执行path程序的arg操作
path就是在当前目录下想要执行的命令,而arg就是命令行参数列表 ,第一个参数是命令行名字,结尾必须为NULL.
int execlp(const char *file, const char *arg, …):
函数作用就是在任何目录下执行file程序的arg操作
int execvp(const char *file, char *const argv[]):
函数作用就是在任何目录下完成file程序argv[]操作
附录: 如果执行了exec族函数 ,那么就会进入到新进程里面 ,不会继续运行之前的进程。
system函数
//函数原型
int system(const char *command);
比起exec族函数 ,更简单粗暴。 直接把命令行传参进去给system就可以了。
command就是命令行。
system("ls -l");
附录:system函数执行完还会继续运行原程序
popen函数
//函数原型
FILE *popen(const char *command, const char *type);
比起system函数,popen函数能够保留运行结果。
command就是命令行 ,而type只有 “r”,“w” 读写俩种。
popen会把运行结果存入管道中 。