1.pid_t fork(void);
作用:创建一个新的进程
返回值:如果调用成功,返回两次。返回值为0,代表当前进程是子进程;返回值为非负数,代表当前进程为父进程。调用失败,返回-1
C程序一开始,就会产生一个进程,当这个进程执行到fork()的时候,会创建一个子进程;此时父进程和子进程是共存的,它们俩会一起向下执行C程序的代码;
注意:子进程创建成功后,fork是返回两个值,一个代表父进程,一个代表子进程:代表父进程的值是一串数字,这串数字是子进程的ID(地址);代表子进程的值为0
#include <stdio.h>
#include <unistd.h>
int main(){
pid_t pid;
printf("pid = %d\n",getpid());
pid = fork();
if(pid > 0 ){
printf("this is father pid:%d\n",getpid());
}else if(pid == 0){
printf("this is child pid:%d\n",getpid());
}
return 0;
}
执行结果:

2、证明fork()函数,返回值为什么有两个值?
fork返回值大于0时,说明当前进程是父进程,这时fork的返回值是子进程的retpid值
然后把fork的返回值retpid,拷贝一份给到子进程,并且把子进程的retpid赋值为0
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
pid_t pid;
pid_t pid2;
pid_t retpid;
pid = getpid();
printf("before fork: pid=%d\n",pid);
retpid = fork();
pid2 = getpid();
printf("after fork: pid=%d\n",pid2);
if(pid == pid2){
printf("this is father print: retpid=%d\n",retpid);
}else{
printf("this is child print: retpid=%d,child pid=%d\n",retpid,getpid());
}
return 0;
执行结果:

3.进程创建发生了什么事
旧版本的Linux拷贝方法:全拷贝,有啥拷啥
新版本的Linux拷贝方法:写实拷贝,写的时候才拷贝(改原文件哪里了,就拷贝哪里,没改的地方,实施共享原则)
全拷贝代码举例:
#include <stdio.h>
#include <unistd.h>
int main(){
pid_t pid;
int data = 100;
printf("pid = %d\n",getpid());
pid = fork();
if(pid > 0 ){
printf("this is father pid:%d\n",getpid());
}else if(pid == 0){
printf("this is child pid:%d\n",getpid());
data = data + 10;
}
printf("data = %d\n",data);
return 0;
}
执行结果:

4.fork创建一个子进程的一般目的
一个父进程希望复制自己,使父进程与子进程同时执行不同的代码段。例如网络进程中,父进程等待客户端的服务请求,请求到达时,调用fork,子进程对请求进行处理,父进程则继续等待下一个请求。
一个进程中要执行不同的程序。子程序从fork返回后立即调用exec。
#include <stdio.h>
#include <unistd.h>
int main(){
pid_t pid;
int data;
while(1){
printf("please input a data :\n");
scanf("%d",&data);
if(data == 1)
{
pid = fork();
if(pid > 0 )
{
}
else if(pid == 0)
{
while(1)
{
printf("do net request, pid=%d\n",getpid());
sleep(3);
}
}
}
else
{
printf("wait,do nothing\n");
}
}
return 0;
}
执行结果:
