创建进程函数fork的使用

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;
}

执行结果:

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值