Linux学习笔记(06-04)创建进程

在Linux中主要提供了fork、vfork、clone三个进程创建方法。

(1)fork 
       fork创建一个进程时,子进程只是完全复制父进程的资源,复制出来的子进程有自己的task_struct结构和pid,但却复制父进程其它所有的资源。例如,要是父进程打开了五个文件,那么子进程也有五个打开的文件,而且这些文件的当前读写指针也停在相同的地方。copy-on-write(COW写时复制)技术:写时复制是在推迟真正的数据拷贝。
fork()调用执行一次返回两个值,对于父进程,fork函数返回子程序的进程号,而对于子程序,fork函数则返回零.
子进程是父进程的副本。它将获得父进程的数据空间,堆和栈的副本,这些都是副本,父子进程并不共享这部分的内存。
父子进程又共享一些东西,简单说来就是程序的正文段。


调用方法 
  #include <sys/types.h> 
    #include <unistd.h> 
    pid_t fork(void); 
    正确返回:在父进程中返回子进程的进程号,在子进程中返回0 
  错误返回:-1

(2)vfork
    用vfork创建的子进程与父进程共享地址空间,也就是说子进程完全运行在父进程的地址空间上,如果这时子进程修改了某个变量,这将影响到父进程。
用 vfork创建子进程后,父进程会被阻塞直到子进程调用exec(exec,将一个新的可执行文件载入到地址空间并执行之。)或exit。
调用方法:
    #include <sys/types.h> 
   #include <unistd.h> 
   pid_t vfork(void); 
  正确返回:在父进程中返回子进程的进程号,在子进程中返回0 
  错误返回:-1

(3)clone 
  系统调用fork()和vfork()是无参数的,而clone()则带有参数。fork()是全部复制,vfork()是共享内存,而clone() 是则可以将父进程资源有选择地复制给子进程,而没有复制的数据结构则通过指针的复制让子进程共享,具体要复制哪些资源给子进程,由参数列表中的 clone_flags来决定。另外,clone()返回的是子进程的pid。
    子进程将文件关闭并将变量修改(调用clone时用到的CLONE_VM、CLONE_FILES标志将使得变量和文件描述符表被共享),父进程随即就感觉到了,这就是clone的特点。由于此处没有设置标志CLONE_VFORK,因此子进程在运行时父进程也不会阻塞,两者同时运行。
调用方法:
    #include <sched.h> 
   int clone(int (*fn)(void *), void *child_stack, int flags, void *arg); 
   正确返回:返回所创建进程的PID,函数中的flags标志用于设置创建子进程时的相关选项。
   错误返回:-1

Note:除了0号进程外,其余的进程均使用系统调用fork()完成

你可能感兴趣的:(Linux学习笔记(06-04)创建进程)