Linux进程概念及其管理调度
进程概述:
传统的程序本身是一组指令的集合,是一个静态实体,无法描述程序在内存中的执行情况,也就不能如实反映程序并发执行过程的特征。
进程是操作系统进行资源分配和高度的独立单位,是程序在计算机上的一次执行过程。进程是动态概念,它可以申请和拥有系统资源,也是活动的实体。
进程由**程序段、数据段和进程控制块**组成。
进程控制块:描述和控制程序运行的一个数据结构,也称为**PCB**。
程序段和数据段:分别存放**进程运行的程序和需要的数据**。
进程特征:**并发性、动态性、异步性、独立性**。
进行执行时间间断性,运行中的进程可能有三种状态:就绪状态、执行状态和阻塞状态。三种基本状态转换方式:**阻塞->就绪,就绪->执行,执行->就绪,执行->阻塞**。
程序是静态,进程是动态。程序作为一种资料长期永久存在,进程是有生命周期,是暂时存在的。同一程序可以对应多个进程。程序并能独立运行,作为资源分配和独立运行的基本单元都是进程。
Linux进程用一个**task_struct**数据结构来表示,它就是Linux进程的PCB。
进程控制块(PCB):进程状态、进程调度信息、进程标识符、进程通信信息、进程链接信息、进程相关的文件信息、进程时间信息、进程虚拟内存信息等。
Linux进程在内存中由三个部分组成:**堆栈段、代码段和数据段**。
Linux调度器将进程分为三个不同的类型:交互进程、批处理进程、监控进程(守护进程)。
进程的创建:
pid_t fork( void);[函数参考](http://pubs.opengroup.org/onlinepubs/9699919799/)
例子
#include <unistd.h>
#include <cstdio>
int main(void)
{
int status;
pid_t pid_child;
pid_child = fork();
printf("pid : %d pid_child : %d\n", getpid(),(int)pid_child);
switch (pid_child)
{
case -1:
printf("fork process create failed!!!\n");
break;
case 0:
printf("fork process create success!!! pid = %d\n", (int)getpid());
break;
default:
printf("default : pPid : %d cPid : %d\n", getpid(), (int)pid_child);
printf("dest_flag0 pid : %d pid_child : %d\n", getpid(),(int)pid_child);
break;
}
printf("dest_flag1 pid : %d pid_child : %d\n", getpid(),(int)pid_child);
return 0;
}
输出结果:
pid : 48793 pid_child : 0
pid : 48787 pid_child : 48793
default : pPid : 48787 cPid : 48793
fork process create success!!! pid = 48793
dest_flag0 pid : 48787 pid_child : 48793
dest_flag1 pid : 48793 pid_child : 0
dest_flag1 pid : 48787 pid_child : 48793
tip:
从以上结果可以看出common path(父子进程都被判断执行的部分)的语句被打印了两次
总结:
fork()函数在执行后:
创建的子进程有一个独特的进程ID。
创建的子进程ID不匹配任何活动的进程组ID。
创建的子进程ID与父进程不同。