1. exec函数族








exec 函数族
背景:fork创建进程之后,子进程和父进程执行相同的代码,但是在实际开发当中,我们希望父子进程执行不同的代码。
作用:执行指定的程序
#include <unistd.h>
int execl(const char *path, const char *arg, ...);
int execlp(const char *file, const char *arg, ...);
成功时执行指定的程序;失败时返回EOF
path 执行的程序名称,包含路径
arg... 传递给执行的程序的参数列表
file 执行的程序的名称,在PATH中查找
注意:两个函数区别execlp不需要写文件名全路径,在PATH查找
最后一个参数必须用空指针(NULL)作结束
进程当前内容被指定的程序替换,但进程号不变
第0个参数必须要写,虽然它没有使用
在execl/execlp这类exec系列函数中,第0个参数 指的是传递给新程序的**argv[0]**,也就是命令行参数列表的第一个元素。
具体说明
- 参数位置 :函数里
arg的第一个值就是第0个参数,比如execl("/bin/ls", "ls", "-l", NULL)中,"ls"就是第0个参数。 - 实际作用 :这个参数会成为新程序
main函数中argv[0]的值,通常用来表示程序自身的名称(而非实际执行的命令参数)。 - 为什么"没使用"却必须写 :
- 从系统层面,exec函数要求参数列表必须以程序名(
argv[0])开头,这是UNIX/Linux的约定,缺少会导致函数调用失败。 - 部分程序会读取
argv[0]做逻辑处理(比如根据不同的argv[0]表现出不同行为),即使多数程序不直接使用,也必须按规则传递。
- 从系统层面,exec函数要求参数列表必须以程序名(
简单说,第0个参数是给新程序的argv[0]传值,是exec函数调用的语法要求,缺一不可。
2. 守护进程






、







3. GDB调试多进程程序
set follow-fork-mode child 设置GDB调试子进程
set follow-fork-mode parent 设置GDB调试父进程
set detach-on-fork on/off 设置GDB跟踪调试单个进程或多个
on: 只调试父进程或子进程的其中一个,(根据follow-fork-mode来决定),这是默认的模式
off:父子进程都在gdb的控制之下,其中一个进程正常调试(根据follow-fork-mode来决定),另一个进程会被设置为暂停状态。
info inferiors 显示GDB调试的进程
inferiors 进程序号(1,2,3...) 切换GDB调试的进程