使用此组合(而不是其他解决方案)有什么好处,即使我们有浪费,该组合仍然可以使人们继续使用它?
您必须以某种方式创建一个新流程。用户空间程序很少有实现此目的的方法。POSIX曾经有
vfork()alognside
fork(),并且某些系统可能具有自己的机制,例如特定于Linux的机制
clone(),但是自2008年以来,POSIX仅指定
fork()和
posix_spawn()系列。该
fork+
exec路线是比较传统的,是很好理解的,并且有一些缺点(见下文)。该
posix_spawn系列专为 特殊用途的
替代品的使用环境中,对于目前的困难
fork();
您可以在其规格的
“
规格
”部分中找到详细信息。
Linux手册页中的以下摘录
vfork()可能很有启发性:
在Linux下,
fork(2)是使用写时复制页面实现的,因此fork(2)唯一的代价就是复制父级的页表并为子级创建唯一的任务结构所需的时间和内存。但是,在过去的糟糕日子中,fork(2)通常需要不必要地制作呼叫者数据空间的完整副本,因为通常在此之后立即exec完成(3)。因此,为了提高效率,BSD引入了vfork()系统调用,该系统调用没有完全复制父进程的地址空间,而是借用了父进程的内存和控制线程,直到发生对execve(2)的调用或退出。当孩子使用其资源时,父进程被暂停。指某东西的用途vfork()很棘手:例如,在父进程中不修改数据取决于知道哪些变量保存在寄存器中。
(已强调)
因此,您对浪费的担忧在现代系统(不限于Linux)中没有充分的根据,但是从历史上看确实是一个问题,并且确实有一些机制可以避免这种情况。如今,这些机制大多数已过时。



