在学习操作系统的时候,肯定会接触到进程(Process)这个概念。
下面介绍在Unix(或者Linux)下利用fork函数创建进程的方法。
fork函数是在<unistd.h>头文件中被定义,是系统的一个服务,
其定义原型为 pid_t fork(void) ,其中pid_t是一个宏定义 #define pid_t int
fork函数是在当前进程中创建一个新的进程,这个新的进程叫做子进程(child process)。当前进程称作父进程(parent process)。系统负责创建父进程的副本,包括代码段,堆和栈的复制。
fork函数是“调用一次,返回两次”。即在父进程中返回生成子进程的ID,(因为父进程拥有不只一个的子进程),在子进程中返回一个整数0(因为子进程只有一个父进程,可以通过调用函数getppid()返回父进程的ID)。如果创建失败,返回-1。
好,下面给出一个简单的例子:
#include <unistd.h> #include <stdio.h> int main() { pid_t pid; //定义进程ID变量 int count=0; //定义计数器 pid = fork(); //调用fork函数 /* * 调用fork函数将创建一个新的进程 * 它们共享同一段程序代码 * 并且父进程和子进程会相继执行下面的程序代码 */ //调试代码 printf( "This is first time, pid = %d\n", pid ); printf( "This is secONd time, pid = %d\n", pid ); count++; //计数器自增 printf( "count = %d\n", count ); if ( pid>0 ) { //父进程执行此段代码 printf( "This is the parent process,the child has the pid:%d\n", pid ); } else if ( !pid ) { //子进程执行此段代码 printf( "This is the child Process.\n") } else { //出错 printf( "fork failed.\n" ); } //调试代码 printf( "This is third time, pid = %d\n", pid ); printf( "This is fouth time, pid = %d\n", pid ); return 0; }
从输出结果,我们可以看出,父进程和子进程都执行了程序代码。而且从count的值可以知道,父进程和子进程分别拥有count变量,即count变量不是共享变量。所以两次打印count值都是1,而不是2。