《Linux内核设计与实现》学习笔记之“Linux进程管理机制”
一.进程(或者称为“任务”)简介
进程是OS最基本的抽象之一,通常进程包括“可执行程序代码”,“其他资源”(如:打开的文件,挂起的信号,内核内部数据,处理器状态,地址空间,一个或多个执行线程等)
二.执行线程简介
执行线程(或称线程)是进程中活动的对象,内核调度的对象是线程,而不是进程,每个线程中都有一个独立的程序计数器,进程栈,进程寄存器
三.进程虚拟机制简介
进程提供了两种虚拟机制(后面的章节,我们还会学习哈~):
1.虚拟处理器:给进程一种假象,让这些进程觉得自己独享处理器(这个需要控制好时间片哈~不能太长也不能太短)
2.虚拟内存: 让进程再获取和使用内存时觉得自己拥有整个系统的所有内存资源
(注:线程之间可以共享虚拟内存,但拥有各自的虚拟处理器)
四.进程在Linux内核中表示的数据结构task_struct
1.内核把进程存放在“任务队列”(一个双向循环链表的结构)中,链表中每一项都是类型为“task_struct(进程描述符)”的结构(<linux/sched.h>中)
2.进程的task_struct是通过slab分配器分配生成的
3.内核通过一个唯一的进程标识值或者PID来标识每个进程。PID是一个数,int类型(最大默认为32768 [short int最大值] )
struct task_struct {
unsigned long state;(判断进程状态的参数)
....
struct task_struct * parent; (指向父进程,涉及资源共享等问题)
struct list_head tasks; (任务链表)
pid_t pid; (进程标识值)
....
....
}
五.进程七大状态
Linux中的进程有7种状态,进程的task_struct结构的state字段指明了该进程的状态。
可运行状态(TASK_RUNNING): 1.正在执行 2.在运行队列中等待执行
可中断的等待(TASK_INTERRUPTIBLE)[进程睡眠中]: 1.等待某些条件的达成,条件一达成,内核会把进程状态设置为运行状态(Running),处于此状态的进程也会因为接收到信号而提前被唤醒并投入运行
不可中断的等待(TASK_UNINTERRUPTIBLE):除了不会因为接到信号而被唤醒从而投入运行外,其他的和(可中断的等待状态一样)
暂停状态(TASK_STOPPED)[停止]: 1.进程没有投入运行也不能投入运行
跟踪状态(TASK_TRACED):进程被调试器暂停或监视。
僵死状态(EXIT_ZOMBIE):进程被终止,但父进程未调用wait类系统调用。
僵死撤销状态(TASK_DEAD):父进程发起wait类系统调用,进程由系统删除。
六.进程上下文和进程家族树
进程上下文:
当一个程序执行了系统调用或者触发了某个异常,它就陷入了内核空间(内核态),称内核“代表进程执行”并处于进程上下文中
系统调用和异常处理程序是对内核明确定义的接口,进程只有通过这些接口才能进入内核执行,对内核的所有访问都必须调用这些接口
进程家族树:
所有的进程都是PID为1的Init进程的后代,内核在系统启动的最后阶段启动init进程,该进程读取“初始化脚本”并执行其他相关程序,最终完成系统启动的整个过程
每个进程描述符(task_struct)中都包含一个指向其父进程的指针(parent),和一个包含所有子进程的链表(children)
关于init进程:
七.进程状态转换图(引用网上图片)

八.进程的创建
创建进程的方法:
1.其他操作系统: 首先在新的地址空间里创建进程,读入可执行文件,最后开始执行
2.Unix/Linux: 用两个函数 fork() 和 exec() 来执行,完成进程创建工作
fork():该调用通过复制一个现有进程来创建一个全新的进程(父进程和子进程的区别仅仅在于PID不同,其他资源的话,父进程和子进程一样)
调用fork()进程的成为父进程,新产生的进程成为子进程,在调用结束后,在返回调用位置,父进程恢复执行,子进程开始执行,fork()系统调用从内核返回两次(一次返回父进程,一次返回子进程)
exec(): 负责读取可执行文件并将其载入地址空间开始运行
(exec()这个家族包括: execve(), execlp(), execle(), execv(), execvp() 等系统调用)
fork()详解:http://www.cnblogs.com/bastard/archive/2012/08/31/2664896.html
九.进程的终结
当一个进程终结时,内核必须释放它所有的资源并告知其父进程
进程的析构发生在它调用exit()后(既可以显式调用,也可以隐式调用[主函数返回时调用])或者遇到异常,也会被动终结
do_exit()(定义于kernel/exit.c中):http://hi.baidu.com/zengzhaonong/item/24cc74c0e74a8b2d46d5c023
十.进程描述符的删除
当调用do_exit()之后,进程已经处于僵死状态,但仍保留了它的进程描述符(能让父进程得到它的状态信息)
。。。。
。。。。
。。。有点事,回来再继续写~~~
《Linux内核设计与实现》学习笔记之“Linux进程管理机制”的更多相关文章
- Linux内核设计与实现——读书笔记2:进程管理
1.进程: (1)处于执行期的程序,但不止是代码,还包括各种程序运行时所需的资源,实际上进程是正在执行的 程序的实时结果. (2)程序的本身并不是进程,进程是处于执行期的程序及其相关资源的总称. (3 ...
- linux内核设计与实现学习笔记-模块
模块 1.概念: 如果让LINUX Kernel单独运行在一个保护区域,那么LINUX Kernel就成为了“单内核”. LINUX Kernel是组件模式的,所谓组件模式是指:LINUX K ...
- Linux内核设计与实现 读书笔记 转
Linux内核设计与实现 读书笔记: http://www.cnblogs.com/wang_yb/tag/linux-kernel/ <深入理解LINUX内存管理> http://bl ...
- linux内核分析第四周学习笔记
linux内核分析第四周学习笔记 标签(空格分隔): 20135328陈都 陈都 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.co ...
- Linux内核分析第二周学习笔记
linux内核分析第二周学习笔记 标签(空格分隔): 20135328陈都 陈都 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.co ...
- linux内核分析第一周学习笔记
linux内核分析第一周学习笔记 标签(空格分隔): 20135328陈都 陈都 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.co ...
- 初探内核之《Linux内核设计与实现》笔记上
内核简介 本篇简单介绍内核相关的基本概念. 主要内容: 单内核和微内核 内核版本号 1. 单内核和微内核 原理 优势 劣势 单内核 整个内核都在一个大内核地址空间上运行. 1. 简单.2. 高效 ...
- Linux内核设计第一周学习总结 计算机如何工作
北京电子科技学院 20135310陈巧然 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-100002 ...
- Linux内核设计与实现 读书笔记
第三章 进程管理 1. fork系统调用从内核返回两次: 一次返回到子进程,一次返回到父进程 2. task_struct结构是用slab分配器分配的,2.6以前的是放在内核栈的栈底的:所有进程的ta ...
- 20135320赵瀚青LINUX内核分析第一周学习笔记
赵瀚青原创作品转载请注明出处<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.概述 第一周的学习内容主 ...
随机推荐
- 从头搭建Spring MVC
1.拷贝jar文件 2.填充Web.xml 在/WEB-INF/web.xml中写入如下内容: <?xml version="1.0" encoding="UTF- ...
- 将UIImage保存到iOS照片库和对应程序沙盒中-b
1.保存到iOS照片库需要引入QuartzCore.framework框架,具体代码如下:.h文件#import <QuartzCore/QuartzCore.h>UIImageView ...
- JNI/NDK开发指南(二)——JVM查找java native方法的规则
通过第一篇文章,大家明白了调用native方法之前,首先要调用System.loadLibrary接口加载一个实现了native方法的动态库才能正常访问,否则就会抛出java.lang.Unsatis ...
- Python读写Redis数据库
import redis class Database: def __init__(self): self.host = 'localhost' self.port = 6379 def write( ...
- Unreal Engine4 蓝图讲解
UE4开发群:344602753 Unread Engine4的界面概况: UE4的效果可以说是比较好的,从整体架构上来说,和Unity3d的逻辑架构不太 一样,发现UE4不好上手,但是从理论上考虑, ...
- 李洪强iOS开发之-cocopods安装
- 《鸟哥的Linux私房菜》读书笔记一
1.CPU为一个具有特定功能的芯片,里面含有微指令集,一个CPU又可以分为两个主要的单元:算术逻辑单元和控制单元.CPU读取的数据都是从内存读取来的,内存内的数据是从输入单元传输来的.CPU处理完也要 ...
- Perl脚本学习经验(三)--Perl中ftp的使用
使用use Net::FTP;Demo: my $Server = '192.168.1.1'; my $User = 'admin'; my $Password = 'admin' ...
- 一台机器上运行多个ActiveMq
由于业务需要一台机器上运行多个ActiveMq,这里主要说一下有什么地方不重复: 1.brokerName名称不能重复 2.端口号不能重复uri = tcp://localhost:50509 3.k ...
- bzoj1559
自动机上状压dp,把单词是否存在压成二进制位注意这里面某些单词会包含其他单词,所以某些自动机上有些状态点对应多个二进制位方案只要再顺着有方案的状态搜一遍即可 ..,'a'..'z'] of longi ...