1、进程的静态特性

进程:程序执行时的一个实例

进程描述符(task_struct): 进程的基本信息(thread_info)、指向内存区描述符的指针(mm_struct)、进程相关的tty(tty_struct)、当前目录(fs_struct)、指向              文件描述符的指针(files_struct)、所接收的信号(signal_struct)

进程状态:1、可运行状态(TASK_RUNNING):正在运行或者准备执行
     2、可中断的等待状态(TASK_INTERRUPTIBLE):进程挂起,产生硬件中断、接收到信号被唤醒进入TASK_RUNNING状态
     3、不可中断的等待状态(TASK_UNINTERRUPTIBLE):类似上述;不能被中断
     4、暂停状态(TASK_STOPPED):进程的执行被暂停
     5、跟踪状态(TASK_TRACED):
     6、僵死状态(EXIT_ZOMBIE):进程的执行被终止,但是父进程没有发布wait()类系统调用,内核不能丢弃包含在死进程描述符中的数据
     7、僵死撤销状态(EXIT_DEAD):父进程发布wait()类系统调用,进程由系统删除。为了避免其他进程的竞争,将进程由僵死状态改为僵死撤销状态。 PID:进程描述符processID,32位系统默认上限32767,64位系统默认上限4194303。用位图表决PID的闲置状态 魔数常量:将2^32做黄金分割,取最接近这个值的一个素数。即0x9e370001(2 654 404 609)= 2^31 + 2^29 - 2^25 + 2^22 - 2^19 - 2^16 +1 进程资源限制:Linux中,进程对系统资源的占用受到一些限制,避免用户过分使用系统资源;CPU时间、地址空间、文件大小、堆大小、栈大小、进程数等等

2、内核如何进行进程切换

硬件上下文:每个进程有自己有地址空间,但是必须共享CPU寄存器;进程恢复前必须装入寄存器的一组数据称为硬件上下文(hardware context)。
     进程切换前,需要先切换硬件上下文;被切换打硬件上下文保存在进程描述符的字段thread_struct的thread字段中。另外通用寄存器的值保留在内核堆栈中。 进程切换:1、切换页全局目录以安装一个新的地址;2、切换内核堆栈和硬件上下文 另外还有一些其他的寄存器或者协处理器:FPU(算术浮点单元)、MMX(multi media extension 多媒体扩展指令集)、SSE/SSE2(Streaming SIMD Extensions)等需要考虑切换; SIMD(single - instruction multiple-data 单指令多数据)

3、进程的创建

提高创建进程效率的方法:写时复制、轻量级进程(允许父子进程共享在内核的很多数据结构)、vfork()创建的进程能共享父进程的内存地址空间。

创建进程的三种方法:clone(), fork(), vfork()

clone(): 创建轻量级进程

fork(): 由clone() 实现, 传入的参数不同

vfork(): 由clone() 实现, 传入的参数不同

进程0: swapper进程、idle进程; 在多处理器系统中,每个CPU都有一个进程0

进程1: 内核进程, 与进程0共享数据,也叫做init进程,它创建和监控在操作系统外层执行的所有进程活动。

4、进程的撤销

exit(): 系统调用,用来终止某一个进程

exit_group(): 系统调用,终止整个线程组

僵尸进程:产生掉一个原因是父进程已死,无法调用wait函数结束子进程,释放其进程描述符。这个时候需要强制子进程称为init进程的子进程,由init来通知释放

5、Linux对多线程程序多支持

深入理解Linux内核-进程的更多相关文章

  1. 深入理解linux内核-进程和程序

    进程描述符task_struct task_struct { //进程基本信息 pid 进程id号 tgid 线程组id号,与线程组领头线程pid号相同   getpid()返回该值 tasks in ...

  2. 读书笔记之Linux系统编程与深入理解Linux内核

    前言 本人再看深入理解Linux内核的时候发现比较难懂,看了Linux系统编程一说后,觉得Linux系统编程还是简单易懂些,并且两本书都是讲Linux比较底层的东西,只不过侧重点不同,本文就以Linu ...

  3. 《深入理解Linux内核》 读书笔记

    深入理解Linux内核 读书笔记 一.概论 操作系统基本概念 多用户系统 允许多个用户登录系统,不同用户之间的有私有的空间 用户和组 每个用于属于一个组,组的权限和其他人的权限,和拥有者的权限不一样. ...

  4. 【读书笔记::深入理解linux内核】内存寻址【转】

    转自:http://www.cnblogs.com/likeyiyy/p/3837272.html 我对linux高端内存的错误理解都是从这篇文章得来的,这篇文章里讲的 物理地址 = 逻辑地址 – 0 ...

  5. 【读书笔记::深入理解linux内核】内存寻址

    我对linux高端内存的错误理解都是从这篇文章得来的,这篇文章里讲的 物理地址 = 逻辑地址 – 0xC0000000:这是内核地址空间的地址转换关系. 这句话瞬间让我惊呆了,根据我的CPU的知识,开 ...

  6. 《深入理解linux内核》第三章 进程

    进程的七种状态 在内核源码的 include/linux/sched.h文件中: task_struct的status可表示 #define TASK_RUNNING 0 #define TASK_I ...

  7. 尝试理解Linux容器进程与宿主机共享内核到底是什么意思?

    背景 近期接触容器技术时,经常看到各类比较容器与虚拟机区别的文章中会提到:容器是共享宿主机的内核,而虚拟机则是拥有自己独立的内核,所以不可能在Linux上用容器运行windows,但是用虚拟机则可以. ...

  8. linux内核--进程与线程

    http://blog.csdn.net/yusiguyuan/article/details/12154823 在<linux内核设计与实现>中第三章讲解了进程管理,在关于进程和线程的概 ...

  9. 理解Linux的进程,线程,PID,LWP,TID,TGID

    在Linux的top和ps命令中,默认看到最多的是pid (process ID),也许你也能看到lwp (thread ID)和tgid (thread group ID for the threa ...

  10. linux内核——进程管理

    在讲进程之前先说一下进程的堆栈的吧: 1.进程的堆栈 内核在创建进程的时候,在创建task_struct的同一时候,会为进程创建对应的堆栈.每一个进程会有两个栈,一个用户栈.存在于用户空间,一个内核栈 ...

随机推荐

  1. 〖Linux〗svn log 每个日志记录只显示一行的方法

    vi ~/.bashrc,增加一个function svnlog(){ svn log "$@" | awk -f <(cat <<EOF #!/usr/bin/ ...

  2. Android如何设置TextView的行间距、行高。

         Android系统中TextView默认行间距比较窄,不美观.     我们可以设置每行的行间距,可以通过属性android:lineSpacingExtra或android:lineSpa ...

  3. 找不到android-support-v4 包的解决办法

    有时候在开发过程中,总是会遇到一些莫名奇妙的错误,或者在使用fragement和viewpage的时候,就会出现下面这个错误,如果出现找不到android-support-v4 包的时候,可以使用下面 ...

  4. java 下对字符串的格式化

    1.对整数进行格式化:%[index$][标识][最小宽度]转换方式         我们可以看到,格式化字符串由4部分组成,其中%[index$]的含义我们上面已经讲过,[最小宽度]的含义也很好理解 ...

  5. 新安装的ubuntu编辑器问题

    转自:https://blog.csdn.net/xiangaichou/article/details/20235041 VI部分 1. 上下左右总是出ABCD,还占行,特难用.这种情况出现在ubu ...

  6. JavaScript escape() unescape() decodeURI()函数对字符串进行编码解码

    定义和用法 escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串. 语法 escape(string) 参数 描述 string 必需.要被转义或编码的字符串. 返回值 已 ...

  7. 【C++】不要想当然使用resize

    #include <iostream> // std::cout #include <vector> // std::vector using namespace std; i ...

  8. 【转】Kafka 之 中级

    摘要: Kafka配置介绍,原理介绍及生产者,消费者Java基本使用方法. 1.    配置 Ø  Broker主要配置 参数 默认值 说明(解释) broker.id =0   每一个broker在 ...

  9. nginx AIO机制与sendfile机制

    nginx AIO机制与sendfile机制 从0.8.11版本开始, nginx 开始支持Linux native aio,如何在nginx里配置使用这套机制是本文介绍的重点.在下面的示例配置中,几 ...

  10. C# winform DataGridView 常见属性

    C# winform DataGridView 属性说明① 取得或者修改当前单元格的内容 ② 设定单元格只读 ③ 不显示最下面的新行 ④ 判断新增行 ⑤ 行的用户删除操作的自定义 ⑥ 行.列的隐藏和删 ...