目录
- execvp vs. execv
- execv
- execvp
- 区别总结
- 在执行子程序时,如下图情况,可以混用。
- execl vs. execv
- execl
- execv
- 区别总结
execvp vs. execv

这两个函数的主要区别在于它们如何处理程序的路径。
execv
execv 函数需要你提供要执行的程序的完整路径,并且使用一个参数数组来传递参数。它的原型如下:
int execv(const char *path, char *const argv[]);
path:要执行的程序的完整路径。argv:一个以NULL结尾的字符串数组,包含了程序的所有参数。
execv 函数在调用时,会替换当前进程的映像为新程序的映像,当前进程的地址空间、打开的文件描述符和当前工作目录等都会被新程序继承。
execvp
execvp 函数则不需要你提供程序的完整路径,它会自动在环境变量 PATH 指定的路径中搜索程序。它的原型如下:
int execvp(const char *file, char *const argv[]);
file:要执行的程序的名称。argv:一个以NULL结尾的字符串数组,包含了程序的所有参数。
execvp 函数在调用时,会使用环境变量 PATH 来查找程序文件的路径,如果找到,它会执行该程序,否则会返回错误。
区别总结
- 路径处理:
execv需要完整的路径,而execvp只需要程序的名称,它会在PATH环境变量指定的路径中搜索程序。 - 使用场景:如果你已经知道程序的完整路径,或者你想要确保执行的是特定路径下的程序,使用
execv。如果你想要让系统自动在PATH中搜索程序,使用execvp。 - 安全性:
execv通常被认为更安全,因为它不允许程序名被篡改,而execvp可能会因为PATH环境变量的设置不当而导致执行错误的程序。
在执行子程序时,如下图情况,可以混用。

execl vs. execv

这两个函数的主要区别在于它们如何处理命令行参数。
execl
execl 函数用于执行另一个程序,并且需要你明确地列出所有参数。它的原型如下:
int execl(const char *path, const char *arg0, ... /* , (char *)0 */);
path:要执行的程序的完整路径。arg0:程序的第一个参数,通常是程序的名称。...:后续的参数,每个参数后面都应该跟着下一个参数,直到最后一个参数,最后一个参数必须是(char *)0来表示参数列表的结束。
execl 函数的优点是简单直观,你可以直接列出所有参数。但是,缺点是你必须知道所有参数,并且参数的数量是有限的,因为 execl 函数的变长参数列表在编译时需要确定。
execv
execv 函数同样用于执行另一个程序,但它使用一个数组来传递参数。它的原型如下:
int execv(const char *path, char *const argv[]);
path:要执行的程序的完整路径。argv:一个以NULL结尾的字符串数组,包含了程序的所有参数。
execv 函数的优点是灵活,你可以在运行时构建参数列表,并且可以处理任意数量的参数。缺点是你需要手动构建参数数组,并且需要确保数组以 NULL 结尾。
区别总结
- 参数传递方式:
execl使用变长参数列表,而execv使用数组。 - 参数数量限制:
execl的参数数量在编译时确定,而execv可以处理任意数量的参数。 - 灵活性:
execv更加灵活,可以在运行时构建参数列表,而execl需要在编译时确定所有参数。 - 使用场景:如果你的程序需要在运行时动态构建参数列表,或者参数数量不确定,使用
execv更加合适。如果参数数量固定,且在编译时已知,execl是一个简单直观的选择。
