一起talk C栗子吧(第七十九回:C语言实例--父进程与子进程)

2024-03-12 05:08

本文主要是介绍一起talk C栗子吧(第七十九回:C语言实例--父进程与子进程),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


各位看官们,大家好,上一回中咱们说的是创建进程的例子,这一回咱们说的例子是:父进程与子进程。闲话休提,言归正转。让我们一起talk C栗子吧!

我们在上一回中介绍了如何使用fork函数创建一个新的进程。这一回中,我们在此基础上介绍父进程与子进程。也可以看作是对fork函数的进一步介绍。

什么是父进程和子进程呢?我们举例子来说明:如果进程A在运行的过程中创建了进程B,那么进程A就是父进程,进程B就是进程A的子进程。这时台下有看官提问了:“既然有父进程了,有没有母进程呢?“我的回答是没有。程序的世界属于父系社会。大家也许听说过C语言之父,C++之父,有没有人听说过C语言之母呢?或者C++之母?哈哈。台下一阵大笑。

接下来,我们通过具体的代码来说明父进程与子进程。下面是具体的代码,请大家参考:

#include<unistd.h>
#include<stdio.h>int main()
{pid_t pid;pid = fork();sleep(5);if(pid > 0){printf("PID: %d -> Father Process is running \n",getpid());}else if(pid == 0){printf("PID: %d -> Son Process is running \n",getpid());}else{printf("Create process failed \n");return 1;}return 0;
}

在上面的代码中,我们使用fork函数创建了一个新进程,该新进程就是一个子进程。大家都知道,子进程和父进程共享相同的资源,比如代码,数据等。因此,在上面的代码中,main函数中的代码既能被父进程运行,也能被子进程运行,也就是说父进程和子进程执行相同的代码。如果真是这样的话,那么父进程和子进程运行时会输出相同的结果。
我们编译并且运行上面的程序,得到以下结果:

$ ./s                                    //运行编译后的程序
PID: 3212 -> Father Process is running   //父进程运行时输出的结果
PID: 3213 -> Son Process is running      //子进程运行时输出的结果

从上面的程序运行结果可以看到,父进程和子进程运行的结果完全不同,这和我们上面分析的结果不一致呀。是程序运行出错了呢,还是我们刚才的分析不正确?

我们检查一下系统中的进程。首先,重新打开一个终端,并且在终端中使用ps命令查看当前系统中的进程,运行结果如下:

$ ps x                                //输入ps x命令并且执行PID TTY      STAT   TIME COMMAND1504 ?        Ssl    0:00 cinnamon-session --session cinnamon...                               //与系统相关的进程暂时忽略3134 pts/2    S+     0:01 vim       //我们在使用的vim进程3147 pts/3    Ss     0:00 bash      3190 pts/4    Ss     0:00 bash3212 pts/3    S+     0:00 ./s       //从PID看,这是父进程3213 pts/3    S+     0:00 ./s       //从PID看,这是子进程3215 pts/4    R+     0:00 ps x      //使用ps命令查看进程

通过上面的结果,我们可以看出,系统中确实运行着两个进程,说明程序运行是正确的。难道是我们刚才的分析不正确?其实,我们刚才的分析和程序的运行结果都没有问题。之所以有这样的结果,是因为fork函数在不同的进程中,会产生不同的结果。

我们在刚才的分析中说:父进程和子进程执行相同的代码,更加具体点就是说,父进程和子进程都执行main函数中的代码。不过,当父进程运行到fork函数哪一行时,它会创建一个新进程,并且返回新进程的PID,这时的PID是一个大于0的正整数,因此,它只会运行下面这段代码:

    if(pid > 0){printf("PID: %d -> Father Process is running \n",getpid());}

当子进程运行到fork函数哪一行时,它不会创建一个新进程,fork函数返回0,这时的PID等于0,因此,它会运行下面这段代码:

    else if(pid == 0){printf("PID: %d -> Son Process is running \n",getpid());}

看官们,现在再回头看看程序的运行结果,是不是有种豁然开朗的感觉?

看官们,正文中就不写代码了,详细的代码放到了我的资源中,大家可以点击这里下载使用。

各位看官,关于父进程与子进程的例子咱们就说到这里。欲知后面还有什么例子,且听下回分解。


这篇关于一起talk C栗子吧(第七十九回:C语言实例--父进程与子进程)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/800222

相关文章

R语言中的正则表达式深度解析

《R语言中的正则表达式深度解析》正则表达式即使用一个字符串来描述、匹配一系列某个语法规则的字符串,通过特定的字母、数字及特殊符号的灵活组合即可完成对任意字符串的匹配,:本文主要介绍R语言中正则表达... 目录前言一、正则表达式的基本概念二、正则表达式的特殊符号三、R语言中正则表达式的应用实例实例一:查找匹配

Go语言结构体标签(Tag)的使用小结

《Go语言结构体标签(Tag)的使用小结》结构体标签Tag是Go语言中附加在结构体字段后的元数据字符串,用于提供额外的属性信息,这些信息可以通过反射在运行时读取和解析,下面就来详细的介绍一下Tag的使... 目录什么是结构体标签?基本语法常见的标签用途1.jsON 序列化/反序列化(最常用)2.数据库操作(

Nginx服务器部署详细代码实例

《Nginx服务器部署详细代码实例》Nginx是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务,:本文主要介绍Nginx服务器部署的相关资料,文中通过代码... 目录Nginx 服务器SSL/TLS 配置动态脚本反向代理总结Nginx 服务器Nginx是一个‌高性

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

C语言逗号运算符和逗号表达式的使用小结

《C语言逗号运算符和逗号表达式的使用小结》本文详细介绍了C语言中的逗号运算符和逗号表达式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 在C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接其一般形式为:表达

Go语言实现桥接模式

《Go语言实现桥接模式》桥接模式是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化,本文就来介绍一下了Go语言实现桥接模式,感兴趣的可以了解一下... 目录简介核心概念为什么使用桥接模式?应用场景案例分析步骤一:定义实现接口步骤二:创建具体实现类步骤三:定义抽象类步骤四:创建扩展抽象类步

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

springboot+mybatis一对多查询+懒加载实例

《springboot+mybatis一对多查询+懒加载实例》文章介绍了如何在SpringBoot和MyBatis中实现一对多查询的懒加载,通过配置MyBatis的`fetchType`属性,可以全局... 目录springboot+myBATis一对多查询+懒加载parent相关代码child 相关代码懒

C++中的解释器模式实例详解

《C++中的解释器模式实例详解》这篇文章总结了C++标准库中的算法分类,还介绍了sort和stable_sort的区别,以及remove和erase的结合使用,结合实例代码给大家介绍的非常详细,感兴趣... 目录1、非修改序列算法1.1 find 和 find_if1.2 count 和 count_if1