C语言创建多个进程 (Linux环境)

3 篇文章 0 订阅

fork可以用来创建一个进程,当我们在一个循环体中,就可以多次fork,创建多个进程,但是由于fork后是多进程一起执行,往往会出现令人意外的情况,请看下面的demo:

#include <stdio.h>  //标准的输入输出函数
#include <stdlib.h> //standard library标准库函数头文件
#include <unistd.h> //对于类 Unix 系统,unistd.h 中所定义的接口通常都是大量针对系统调用的封装 fork、

int main()
{
    pid_t pid;
    int i;
    for (i = 0; i < 5; ++i)
    {
        pid=fork();
        // 这是异常情况
        if (pid==-1)
        {
            perror("fork失败!");
            exit(1);
        }
    }

    //返回大于0的进程就是父进程
    if(pid>0)  //父进程
    {
        printf("父进程: pid= %d , ppid=%d,子进程: %d \n", getpid(),getppid(),pid);
        sleep(1); //这里延迟父进程程序,等子进程先执行完。
    }
    else if(pid==0)  //子进程
    { 
        printf("i的变量是: %d 子进程: pid= %d , ppid=%d \n", i,getpid(),getppid());
    }

    return 0; //养成好习惯,返回程序执行状态码
}

执行编译后,执行输出,./a.out,输出结果如下:

总共有32个进程出来,原本是想创建五个子进程,为什么呢?

原因在于在fork后,循环体for的逻辑在子进程也会执行,这样就变成了子进程也会fork子进程,而再次循环子进程又会创建子进程,如果反复五次,是呈现指数增加的,所以是2的5次方,32个进程。

这并不是我们想要的结果,所以需要避免子进程继续fork

#include <stdio.h>  //标准的输入输出函数
#include <stdlib.h> //standard library标准库函数头文件
#include <unistd.h> //对于类 Unix 系统,unistd.h 中所定义的接口通常都是大量针对系统调用的封装 fork、

int main()
{
    pid_t pid;
    int i;
    for (i = 0; i < 5; ++i)
    {
        pid=fork();
        // 这是异常情况
        if (pid==-1)
        {
            perror("fork失败!");
            exit(1);
        }

        //循环中,fork函数调用五次,子进程返回0,父进程返回子进程的pid,
        //为了避免子进程也fork,需要判断并break
        if (pid==0)
        {
            break;
        }
    }

    //返回大于0的进程就是父进程
    if(pid>0)  //父进程
    {
        printf("父进程: pid= %d , ppid=%d,子进程: %d \n", getpid(),getppid(),pid);
        sleep(1); //这里延迟父进程程序,等子进程先执行完。
    }
    else if(pid==0)  //子进程
    { 
        printf("i的变量是: %d 子进程: pid= %d , ppid=%d \n", i,getpid(),getppid());
    }

    return 0; //养成好习惯,返回程序执行状态码
}

执行编译后,执行输出,./a.out,输出结果如下:

以上是学习linux编程基础一书的笔记。

  • 18
    点赞
  • 87
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Linux系统中,你可以使用C语言中的fork()函数来创建多个进程。fork()函数会创建一个与当前进程完全相同的子进程,并且这两个进程将在fork()函数的返回处开始执行不同的代码。 下面是一个简单的示例,演示如何使用fork()函数创建多个进程: ```c #include <stdio.h> #include <unistd.h> #include <sys/types.h> int main() { pid_t pid; // 使用fork()函数创建一个新的子进程 pid = fork(); if (pid < 0) { // fork()失败,创建进程失败 fprintf(stderr, "Fork failed\n"); return 1; } else if (pid == 0) { // 子进程执行的代码 printf("This is the child process\n"); // 子进程执行完毕后退出 return 0; } else { // 父进程执行的代码 printf("This is the parent process\n"); // 父进程等待子进程结束 wait(NULL); printf("Child process finished\n"); // 父进程执行完毕后退出 return 0; } } ``` 在这个示例中,父进程使用fork()函数创建了一个子进程。父进程和子进程将分别输出不同的信息。父进程通过wait()函数等待子进程结束,并输出相关信息。 请注意,fork()函数会在父进程和子进程中返回不同的值。在父进程中,fork()函数返回子进程进程ID;在子进程中,fork()函数返回0。这样可以通过不同的返回值来区分父进程和子进程的执行路径。 通过多次调用fork()函数,你可以创建更多的子进程。每个子进程都会从fork()函数后面开始执行不同的代码。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值