1.进程介绍
进程是计算机中的程序关于某数据集合.上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。
2.fork函数
fork函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
进程创建后,系统给新创建的子进程分配资源。我们可以通过进程号pid来区分父进程和子进程。父进程返回的是子进程的pid,子进程返回的是0。

四个函数:
getpid()返回当前进程的进程ID,
getppid()返回当前进程的父进程ID,
getuid(),获取某个进程的用户的uid,
getgid() ;获取执行目前进程的组识别码gid
pid. _t类型表示进程ID,但为了表示-1,它是有符号整型。(0不是有效进程ID, init最小,为1)。
注意返回值,不是fork函数能返回两个值,而是fork 后, fork 函数变为两个,父子需[各自]返回
一个。
例程:创建一个子进程
#include <stdio.h>
#include <sys/types . h>
#include <unistd .h>
int main
{
pid_ _t pid;
pid= forkO;
if(pi d<0)
{
perror("fail");
}
else if(pid==0)
{
printf("我是子进程getpid=%d,父进程getppi d=%d\n" , getpidO,getppidO);
else
printf("我是父进程,getpid=%d\n" ,getpidO);
printf("我是进程创建后的公共内容\n");
}
return 0;
}
例程:编写一个程序,使用fork函数创建两个子进程和一个父进程

循环创建5个子进程

3.进程共享
父子进程遵循读时共享写时复制的原则。

目的为了节省内容空间
本文介绍了Linux操作系统中的进程概念,作为资源分配和调度的基本单位,进程在系统中的地位至关重要。接着详细讲解了fork函数的工作原理,如何通过fork创建子进程,并且描述了在创建过程中父子进程的标识及资源分配。同时,提到了进程共享的机制,遵循读时共享、写时复制的原则,以实现高效的内容空间管理。

被折叠的 条评论
为什么被折叠?



