在Linux中,有多种方法可以创建新进程
fork()
系统调用用于创建一个当前进程的完全复制品。新进程(子进程)从调用fork()
的地方开始执行,具有相同的内存映像、环境变量和文件描述符。子进程与父进程的区别在于其进程ID(PID)不同,且子进程不会自动继承父进程的某些属性,如信号处理函数等。
exec()
系统调用用于在当前进程的上下文中替换一个新的程序。一旦执行了exec()
,之前的进程图像将被新的程序替换。exec()
系列函数有多个变种,如execl()
、execv()
、execle()
等,它们提供了不同的参数传递方式。
以下是一个简单的示例,展示了如何使用fork()
和exec()
创建新进程:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/wait.h>
int main() {
pid_t pid = fork();
if (pid == 0) { // 子进程
char *argv[] = {"ls", "-l", NULL};
execv(argv[0], argv);
perror("execv");
exit(EXIT_FAILURE);
} else if (pid > 0) { // 父进程
int status;
waitpid(pid, &status, 0);
printf("子进程已结束,状态码:%d\n", WEXITSTATUS(status));
} else {
perror("fork");
exit(EXIT_FAILURE);
}
return 0;
}
system()
函数:system()
函数是一个高级的进程创建方法,它允许您在当前进程中执行一个shell命令。system()
函数返回命令的退出状态。
示例:
#include <stdio.h>
#include <stdlib.h>
int main() {
int status = system("ls -l");
printf("命令退出状态:%d\n", WEXITSTATUS(status));
return 0;
}
请注意,system()
函数使用shell来执行命令,因此可能会受到shell注入攻击的影响。在实际应用中,建议使用fork()
和exec()
系统调用进行进程创建。