函数fork vfork

一、函数fork

fork函数原型:

#include <unistd.h>
pid_t fork(void);

 

二、程序清单

1. 测试代码:

#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
#include <fcntl.h>
#include <iostream>
using namespace std;static int global_val = 0;
int main()
{int *p = (int*)malloc(sizeof(int));*p = 0;int m = 2;pid_t pid;int fd = open("mytest", O_RDWR | O_CREAT, 0666);if ((pid = fork()) < 0){cout << "fork error" << endl;}else {if (pid == 0){char buf[20] = "\0";int res = read(fd, buf, 20);cout << "pid is " << getpid() << " res is " << res << " fd is " << fd << " buf is " << buf << endl;close(fd);//sleep(1);char bufs[8] = "shenlei";lseek(fd, 0, SEEK_SET);write(fd, bufs, strlen(bufs));global_val++;m++;(*p)++;}else {sleep(1);char buf[20] = "\0";lseek(fd, 0, SEEK_SET);int res = read(fd, buf, 20);cout << "pid is " << getpid() << " res is " << res << " fd is " << fd << " buf is " << buf << endl;cout << *p << " " << m << " " << global_val << endl;}}return 0;
}
#include <stdio.h>
#include <unistd.h>int main()
{pid_t pid;for(int i = 0; i < 4; ++i)printf("--------i = %d\n", i);pid = fork();if(pid > 0) printf("parent process, pid = %d\n", getpid());else if(pid == 0)printf("child process, pid = %d, ppid = %d\n", getpid(), getppid());for(int i = 0; i < 4; ++i)printf("i = %d\n", i);return 0;
}

输出结果:

 

2. 测试代码:

#include <stdio.h>
#include <unistd.h>int counter = 200;
int main()
{int number = 5;int i;pid_t pid;for(i  = 0; i < number; ++i) {pid = fork();if(pid == 0) {break;}}if(i == 0){counter += 200;printf("first process, pid = %d\n", getpid());printf("-----couner = %d\n", counter);}if(i == 1){counter += 200;printf("second process, pid = %d\n", getpid());printf("-----couner = %d\n", counter);}if(i == 2){counter += 200;printf("thrid process, pid = %d\n", getpid());printf("-----couner = %d\n", counter);}if(i == number){sleep(3);counter += 400;printf("parent process, pid = %d\n", getpid());printf("-----couner = %d\n", counter);}return 0;
}

输出结果:

3. 测试代码:

#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>int main()
{int i;pid_t pid;printf("xxxxxxxxxxxxxxxxxxxxx\n");for(i = 0; i < 5; ++i) {pid = fork();if(pid == -1) {perror("fork error:");exit(1);} else if(pid == 0) {break;}}if(i < 5) {sleep(i);printf("I'am %d child, pid = %d\n", i+1, getpid());} else {sleep(i);printf("I'am parent\n");}return 0;
}

输出结果:

 

三、父子进程共享

父子进程之间在fork后,有哪些相同,有哪些相异之处呢?

刚fork之后:

父子相同处:全局变量、.data、.text、栈、堆、环境变量、用户ID、宿主ID(家目录)、进程工作目录、信号处理方式
父子不同处:进程ID、fork返回值、父进程ID、进程运行时间、闹钟(定时器)、未决信号集

似乎,子进程复制了父进程0-3G用户空间内容,以及父进程的PCB、但pid不同,真的每fork一个进程都要将父进程完全程的0-3G地址空间完全拷贝一份,然后在映射至物理内存吗?

当然不是!父子进程间遵循读时共享写时复制的原则,这样设计,无论子进程执行父进程的逻辑还是执行自己的逻辑都能节省内存开销。

重点注意:躲避父子进程共享全局变量的知识误区!

【重点】:父子进程共享:1. 文件描述符(打开文件的结构体)  2. mmap建立的映射区

 

1. 测试代码:

#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>int var = 24;int main()
{pid_t pid;pid = fork();if(pid == -1) {perror("fork");exit(1);} else if(pid > 0) {var = 55;sleep(1);printf("I'am parent pid = %d, parent ID = %d, var = %d\n", getpid(), getppid(), var);} else if(pid == 0) {var = 100;printf("child pid = %d, parent ID = %d, var = %d\n", getpid(), getppid(), var);}printf(" var = %d\n", var);    return 0;
}

输出结果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385586.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【金三银四】微软java后端社招

分布式系统特性与衡量标准 透明性&#xff1a;使用分布式系统的用户并不关心系统是怎么实现的&#xff0c;也不关心读到的数据来自哪个节点&#xff0c;对用户而言&#xff0c;分布式系统的最高境界是用户根本感知不到这是一个分布式系统 可扩展性&#xff1a;分布式系统的根…

【面试必会】java虚拟机原理

如何才可以进大厂&#xff1f; 答案其实也很简单&#xff0c;能力学历。不知道大家有没有发现&#xff0c;大厂的一些部门对于学历要求已经放低了&#xff0c;阿里的一些部门同样也招大专学历的程序员&#xff0c;当然肯定也是因为他的能力足够出色。 对于准备秋招的你来说&a…

函数exec

exec函数族 1. 执行指定目录下的程序 #include <unistd.h> int execl(const char *path, const char *arg, ...);返回值&#xff1a;若出错&#xff0c;返回-1&#xff1b;若成功&#xff0c;不返回 分析&#xff1a; path: 要执行的程序的绝对路径变参arg: 要执行的…

【面试必备】java写spark好不好

并发编程三大特性 原子性 一个操作或者多次操作&#xff0c;要么所有的操作全部都得到执行并且不会受到任何因素的干扰而中断&#xff0c;要么所有的操作都执行&#xff0c;要么都不执行。 对于基本数据类型的访问&#xff0c;读写都是原子性的【long和double可能例外】。 …

【面试必备】java面试题视频讲解

二、我们先来看看这份笔记到底有什么 1、先把kubernetes跑起来&#xff08;先跑起来创建kubernetes集群部署应用访问应用Scale应用滚动更新&#xff09; 2、重要概念 3、部署kubernetes Cluster&#xff08;安装docker安装 kubelet.kubeadm和 kubectll用kubeadm 创建cluster&a…

【面试总结】java测试工程师培训

阿里P8级架构师核心理论落地篇 再造淘宝&#xff0c;贯穿全系&#xff0c;阿里团队代码落地&#xff0c;详细每个版本迭代&#xff0c;拒绝2-3个月PPT架构师再造淘宝之咚宝-技术支撑-完整搭建DevOps再造淘宝之咚宝-统一规则-代码规范落地解析再造淘宝之咚宝搭建基础服务再造淘…

进程组的应用

一、实验1 题目&#xff1a;利用进程扇完成一个小实验。该进程扇有 1 个父进程和 3 个子进程&#xff0c;我们希望达到图 1 中的效果&#xff0c;即将进程 0 (父进程)和进程 1 设置成一组&#xff0c;假设为组 1&#xff0c;将进程 2 和 进程 3 设置成另一个组&#xff0c;假设…

【原理+实战+视频+源码】docker映射端口教程

阿里巴巴Java岗面试题分享 1.HashMap 的内部结构&#xff1f;内部原理&#xff1f;和 HashTable 的区别&#xff0c;假如发⽣了 hash 碰撞&#xff0c;如何设计能让遍历效率⾼&#xff1f; 2.讲一讲讲讲 ConcurrentHashMap吧。 3.讲一下JVM虚拟机内存结构&#xff0c;以及它…

前台进程组、后台进程组

一、前台进程组、后台进程组 cat | cat & cat | cat | cat 输出结果&#xff1a; 二、主要函数应用 1. tcgetpgrp函数原型&#xff1a; #include <unistd.h> pid_t tcgetpgrp(int fd);返回值&#xff1a;若成功&#xff0c;返回前台进程组ID, 若出错&#xff0c;…

【原理+实战+视频+源码】docker权限参数

一面&#xff1a; 个人介绍加项目介绍20分钟 微服务架构是什么&#xff0c;它的优缺点&#xff1f; ACID CAP BASE理论 分布式一致性协议&#xff0c;二段、三段、TCC&#xff0c;优缺点 RPC过程 服务注册中心宕机了怎么办&#xff1f; 微服务还有其他什么组件 分布式架…

【孤儿进程】孤儿进程组、守护进程

一、孤儿进程组 1. 孤儿进程的定义&#xff1a; 定义1&#xff1a;该进程组的每个成员的父进程要么是该组的成员&#xff0c;要么在其它会话中。 定义2&#xff1a;一个进程不是孤儿进程组的条件是——该组有一个进程&#xff0c;其父进程在属于同一会话的另一个组中。 只要能…

【吐血整理】用java编写一个登陆界面

结构化数据、非结构化数据与半结构化数据 文章的开始&#xff0c;聊一下结构化数据、非结构化数据与半结构化数据&#xff0c;因为数据特点的不同&#xff0c;将在技术上直接影响存储引擎的选型。 首先是结构化数据&#xff0c;根据定义结构化数据指的是由二维表结构来逻辑表…

【大牛疯狂教学】cdhkafka打开的文件描述符临界阈值

基本知识 1.学会分析源码 程序员每天都和代码打交道。经过数年的基础教育和职业培训&#xff0c;大部分程序员都会「写」代码&#xff0c;或者至少会抄代码和改代码。但是&#xff0c;会读代码的并不在多数&#xff0c;会读代码又真正读懂一些大项目的源码的&#xff0c;少之…

线程清理函数

一、线程清理函数 #include <pthread.h> void ptread_clean_push(void (*rtn) (void *), void *arg); 注册清理函数&#xff0c;押栈 void ptread_clean_pop(int excute); 清理函数&#xff0c;出栈 分析&#xff1a;这两个函数是成对出现的…

【大牛疯狂教学】mysqlinnodb和myisam

02 JVM 线程JVM内存区域JVM运行时内存垃圾回收与算法JAVA四种引用类型GC分代收集算法 VS 分区收集算法GC垃圾收集器JAVA IO/NIOJVM类加载器 03 JAVA集合 接口继承关系和实现LISTSETMAP 04 JAVA多线程并发 JAVA并发知识库JAVA线程实现/创建方式4种线程池线程生命周期&#xf…

【大牛疯狂教学】深入拆解java虚拟机百度云

Java基础核心笔记总结 由于篇幅限制&#xff0c;我就只以截图展示目录内容以及部分笔记内容&#xff0c;获取完整版王者级核心宝典只需要点击点赞关注即可获取领取方式&#xff01; 在这个部分我们总结了Java的基础知识&#xff0c;涵盖了&#xff1a;概述、开发环境、开发环境…

【大牛系列教学】docker.service配置文件详情

01 阿里中间件&#xff08;四面&#xff0c;Java岗&#xff09; 1.1 Java中间件一面 技术一面考察范围 重点问了Java线程锁&#xff1a;synchronized 和ReentrantLock相关的底层实现 线程池的底层实现以及常见的参数 数据结构基本都问了一遍&#xff1a;链表、队列等 Java内存…

【大牛系列教学】java面试常考的编程题

1. 面试官&#xff1a;工作中使用过Zookeeper嘛&#xff1f;你知道它是什么&#xff0c;有什么用途呢&#xff1f; 小菜鸡的我&#xff1a; 有使用过的&#xff0c;使用ZooKeeper作为dubbo的注册中心&#xff0c;使用ZooKeeper实现分布式锁。ZooKeeper&#xff0c;它是一个开…

中断的系统调用

系统调用可分为两类&#xff1a;慢速系统调用和其他系统调用 慢速系统调用&#xff1a;可能会使进程永远阻塞的一类&#xff0c;如果在阻塞期间收到一个信号&#xff0c;该系统调用就被中断&#xff0c;不再继续执行(早期)&#xff1b;也可以设定系统调用是否重启。如&#xf…

【好文推荐】java模板引擎性能

01. 基础架构&#xff1a;一条SQL查询语句是如何执行的&#xff1f; MySQL 的逻辑架构图 02. 日志系统&#xff1a;一条SQL更新语句是如何执行的&#xff1f; 之前你可能经常听DBA同事说&#xff0c;MySQL可以恢复到半个月内任意一秒的状态&#xff0c;惊叹的同时&#xff0c;…