热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linuxfork函数创建进程

@Linux系统进程进程相关解释进程:运行起来的程序在内存中的镜像进程号:系统分配给进程的一个编号,用于标记该进程,便于系统调度管理该进程。进程号唯一,进程号也是有限。进程结束后,

@Linux系统进程

进程相关解释

进程:运行起来的程序在内存中的镜像

进程号:系统分配给进程的一个编号,用于标记该进程, 便于系统调度管理 该进程。进程号唯一,进程号也是有限。进程结束后,会将进程号归还系统。系统可以将归还的进程号分配给新的进程。

进程控制块(pcb):一块内存空间,存放进程的相关信息,便于系统管理。进程号,打开的文件列表,信号列表…

并发:宏观上,多个程序同时运行;微观上,某个时刻,只有一个程序在运行

进程调度算法:先来先执行,短作业优先原则,时间片轮转,优先级调度,多优先级队列时间片轮转

fock()函数创建进程

#include
#include
pid_t fork(void);

fork()通过复制调用进程来创建一个新进程。新进流程被称为子进程。原进程被称为父进程。

子进程和父进程在不同的内存空间中运行。在fork()时,两个内存空间具有相同的内容。 其中一个过程不会影响另一个进程。

成功后,子进程的进程号将在父进程中返回,并且在子进程中返回0。失败时,在父级中返回-1,没有创建子进程。

#include
#include
#include
#include
#include
int main(void)
{
int i = 0;
char caMsg[128] = { '\0'};
pid_t pid = -1;
pid = fork();
if (pid > 0) //parent
{
i = 3;
printf("parent msg addr = 0x%p\n", caMsg);
strcpy(caMsg, "this is parent...");
}
else if (0 == pid) //child
{
i = 6;
printf("child msg addr = 0x%p\n", caMsg);
strcpy(caMsg, "this is child...");
}
else if (-1 == pid)
{
perror("fork");
exit(EXIT_FAILURE);
}
for (; i>0; i--)
{
printf("%s\n", caMsg);
sleep(1);
}
return 0;
}

《Linux fork函数创建进程》
虽然在Linux中运行显示父进程与子进程地址一样,但其并不相同。

猜猜有几个进程

1.打印多少个g?

#include
#include
#include
int main(void)
{
for(int i=0;i<2;i++)
{
fork();
printf("g\n");
}
return 0;
}

2.打印多少个g?

int main(void)
{
//总共有多少个进程
int i = 0;
for (; i<2; i++)
{
fork();
printf("g");
}
return 0;
}

答案1、6个 2、8个


推荐阅读
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • 本文介绍了C函数ispunct()的用法及示例代码。ispunct()函数用于检查传递的字符是否是标点符号,如果是标点符号则返回非零值,否则返回零。示例代码演示了如何使用ispunct()函数来判断字符是否为标点符号。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • 本文介绍了一个题目的解法,通过二分答案来解决问题,但困难在于如何进行检查。文章提供了一种逃逸方式,通过移动最慢的宿管来锁门时跑到更居中的位置,从而使所有合格的寝室都居中。文章还提到可以分开判断两边的情况,并使用前缀和的方式来求出在任意时刻能够到达宿管即将锁门的寝室的人数。最后,文章提到可以改成O(n)的直接枚举来解决问题。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
author-avatar
victor
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有