一、从内存的角度分析父子进程资源问题
父子进程在内存资源使用上既共享又独立。它们通过写时复制技术实现地址空间的共享,但在修改数据时各自维护独立副本。代码段共享以节省内存,同时继承并打开的文件描述符等系统资源需注意同步和互斥问题。这种特殊的资源使用方式使得父子进程管理更加灵活高效。
结果:父子进程a的地址都是一样,但是父进程中的变量a 和 子进程中的变量a 互不影响,结论:
1、父进程在fork()时,会将父进程的空间拷贝一份给子进程
2、父进程与子进程 拥有独立的内存空间,互不影响。
二、产生子进程的另一个函数vfork()
#include <sys/types.h>
#include <unistd.h>
pid_t vfork(void);
参数:
vfork()
不接受任何参数。返回值:
- 成功时,
vfork()
在父进程中返回新创建的子进程的 PID(进程ID)。- 在子进程中,
vfork()
返回 0。- 如果创建子进程失败,
vfork()
在父进程中返回 -1,并设置errno
以指示错误原因。错误原因可能包括:
EAGAIN
:系统资源限制,无法创建更多的进程。ENOMEM
:没有足够的内存来创建新的进程。重要注意事项:
- 调用
vfork()
后,父进程必须等待子进程通过调用exit()
或执行一个exec()
系列函数来结束,因为子进程会共享父进程的地址空间。如果父进程在子进程调用exec()
或exit()
之前尝试继续执行,那么结果将是未定义的。- 由于
vfork()
的这些特殊性和潜在的风险,它通常只在特定的、性能敏感的场景中使用,而在更一般的场景下推荐使用fork()
。