Process学习
主要系统总结下我对进程的认识,以前理解得不够全面不够深入。本文肯定还不够好,当有新的认识新的理解后还会随时来更新。读完本文,下面几个问题便可理解清楚。
1.进程是什么?
2.为什么要有进程这个概念?
3.进程需要哪些成分?
4.进程怎么管理?
5.进程状态?
进程的定义
进程就是计算机程序被执行的实例。linux系统可以top命令查看进程,大部分人还是用windows,你应该有过电脑很卡的时候吧?这个时候怎么办?Ctrl+Alt+Del打开任务管理器,查看是哪个或哪几个进程占用了大部分的cpu,关掉后,你的电脑又开始流畅起来了。
为什么要有进程
操作系统就是由很多程序代码组成的,只是非常复杂。一个程序的执行是这样的,首先,程序代码在辅助存储器(一般是硬盘)里,加载到主存(memory),cpu分配资源和处理器时间给机器码(代码最终都必须编译成机器码)。一个cpu只能执行一个程序,如果不采取诸如多线程之类的技术,计算机中那么多程序要使用cpu呢?虽然现在已经有多核cpu了,但是和程序的数量比,还是不够。那么多程序要争夺cpu使用权,是不是需要好好管理下,进程就是为了这个使命而诞生的,有了进程,管理和调度进入主存的程序就会比较方便。
进程的组成
进程由5部分组成:
(1)和程序相关的可执行的机器码的一个镜像;(代码的最终形态,就是一些指令的集合,只不过现在是0101)
(2)主存;(要存放code,data等)
(3)操作系统资源描述符;(文件描述符,数据来源等)
(4)安全属性;(英文叫security attributes,进程拥有者或进程权限)
(5)进程context;(寄存器的内容,物理内存地址等)
进程的管理
管理进程所需要的信息在process control blocks里面。这个数据结构在操作系统内核里。管理一个进程所需要的信息就存储在这个数据结构里面了。里面有哪些信息呢?
(1)进程识别数据;
(2)处理器状态数据;
(3)进程控制数据。
os就是通过进程识别数据(进程id)来识别不同进程,根据处理器状态数据和进程控制数据来管理进程。
进程的状态

Wating,Running,Blocked状态下的进程在主存里。
当一个进程"Created"的时候,process就从辅助存储器加载到主存,process scheduler给process一个状态"Waitting"。之所以有个Waitting是因为要进入Running状态需要些准备工作,这个著名的准备工作叫context switch(就是上下文环境切换,一个进程的某个时刻的信息的记录),当scheduler完成context switch后,process就进入处理器,状态更新为"running",处理器执行指令。
当一个进程需要等待资源(等待用户输入或打开文件)时,process就变为“blocked”状态,当等待的资源来到时,process就进入“watting”状态。
当一个process完成任务或被用户强行中断,process就进入“Terminated”状态。主存里关于这个process的所有数据将被删除。
Process学习的更多相关文章
- salesforce 零基础学习(三十五) 通过Process Builder和Approval Processes锁定记录(Lock Record)
有的时候我们可能有这样的需求,当某个字段为特定的值情况下,便锁定此条记录,仅允许Profile为System Admin的用户修改或者解锁,其他的用户只能查看此条记录,不能修改此条记录,这种情况下我们 ...
- 本人AI知识体系导航 - AI menu
Relevant Readable Links Name Interesting topic Comment Edwin Chen 非参贝叶斯 徐亦达老板 Dirichlet Process 学习 ...
- JAVA 学习随笔 : JDK Enhancement Process JEP process
是时候寻找一个学习JAVA的路径了 ---- JDK Enhancement Process Oracle发布了JDK增强提案与路线图进程,目的在于鼓励OpenJDK提交者贡献点子和扩展以改进Open ...
- Dynamic CRM 2013学习笔记(三十九)流程2 - 业务流程(Business Process Flows)用法详解
业务流程(Business Process Flows)是CRM 2013 里一个新的流程,它提供了可视化的流程表现.业务人员创建有效.流线型的业务流程让最终用户知道当前在哪.下一步要做什么,用户可以 ...
- contiki-main.c 中的process系列函数学习笔记 <contiki学习笔记之六>
说明:本文依然依赖于 contiki/platform/native/contiki-main.c 文件. ---------------------------------------------- ...
- node学习 process笔记
如果你是node大神好了可以关闭此页面了因为接下来游览会白白浪费你许多时间,最近一直学习node.js今晚看到 alsotang 在 github上的node教程 https://github.com ...
- Node.js实战项目学习系列(4) node 对象(global、process进程、debug调试)
前言 在之前的课程我们学习了Node的模块化规则,接下来我们将学习下 Node的几个新特性:global ,process进程,debug调试 global 跟在浏览器中的window一样都是全局变量 ...
- Flink学习笔记:Operators之Process Function
本文为<Flink大数据项目实战>学习笔记,想通过视频系统学习Flink这个最火爆的大数据计算框架的同学,推荐学习课程: Flink大数据项目实战:http://t.cn/EJtKhaz ...
- 学习动态性能表(7)--v$process
学习动态性能表 第七篇--V$PROCESS 2007.5.30 本视图包含当前系统oracle运行的所有进程信息.常被用于将oracle或服务进程的操作系统进程ID与数据库session之间建立联 ...
随机推荐
- Android-xUtils框架介绍(三)
继续介绍xUtils的最后两个模块:DbUtils和HttpUtils.首先先介绍第一个SQLite数据库操纵的简单ORM框架,只要能理解xUtils为我们提供的api,相信你也能熟练的把DbUtil ...
- poj2482Stars in Your Window(线段树+离散化+扫描线)
http://poj.org/problem?id=2482 类似于上一篇 这题转化的比较巧妙 将一个点转化为一个矩形(x,y, x+w,y+h),扫描线入值为正 出值为负 也就是一根线过去 每进入一 ...
- Android 启动过程总结
SystemServer的启动 frameworks/base/services/java/com/android/server/SystemServer.java: run() 其中调用Activi ...
- bzoj3196
平衡树系列终于完结,撒花 裸的树套树,扔代码跑 ; ..] of longint; son:..,..] of longint; a,root:..*] of longint; i,n,m,x,y,k ...
- [2015编程之美] 资格赛C
#1150 : 基站选址 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 需要在一个N × M的网格中建立一个通讯基站,通讯基站仅必须建立在格点上. 网格中有A个用户,每个 ...
- Vim Vundle 插件管理器
/********************************************************************** * Vim Vundle 插件管理器 * 说明: * 话 ...
- 【转】JAVA中的反射机制
反射,当时经常听他们说,自己也看过一些资料,也可能在设计模式中使用过,但是感觉对它没有一个较深入的了解,这次重新学习了一下,感觉还行吧! 一,先看一下反射的概念: 主要是指程序可以访问,检测和修改它本 ...
- mkimage的-a 和 –c参数和内核引导
目录 一.mkimage工具简介二.-a参数与-e参数和内核引导的关系三.实例测试 3.1 -a参数与-e参数相同,可以将内核下载到SDRAM的任何地址,然后从这启动 3.2 -a参数与-e参数不同, ...
- ArcGIS for Android示例解析之离线地图-----LocalTiledLayer
转自:http://blog.csdn.net/wozaifeiyang0/article/details/7327423 LocalTiledLayer 看到这个标题是否是很激动,如题,该示例就是添 ...
- 在.net中用Connection对象数据源的架构信息
可得到数据库中的,表,视图,等信息 string strcon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source = " + fi ...