主要系统总结下我对进程的认识,以前理解得不够全面不够深入。本文肯定还不够好,当有新的认识新的理解后还会随时来更新。读完本文,下面几个问题便可理解清楚。

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学习的更多相关文章

  1. salesforce 零基础学习(三十五) 通过Process Builder和Approval Processes锁定记录(Lock Record)

    有的时候我们可能有这样的需求,当某个字段为特定的值情况下,便锁定此条记录,仅允许Profile为System Admin的用户修改或者解锁,其他的用户只能查看此条记录,不能修改此条记录,这种情况下我们 ...

  2. 本人AI知识体系导航 - AI menu

    Relevant Readable Links Name Interesting topic Comment Edwin Chen 非参贝叶斯   徐亦达老板 Dirichlet Process 学习 ...

  3. JAVA 学习随笔 : JDK Enhancement Process JEP process

    是时候寻找一个学习JAVA的路径了 ---- JDK Enhancement Process Oracle发布了JDK增强提案与路线图进程,目的在于鼓励OpenJDK提交者贡献点子和扩展以改进Open ...

  4. Dynamic CRM 2013学习笔记(三十九)流程2 - 业务流程(Business Process Flows)用法详解

    业务流程(Business Process Flows)是CRM 2013 里一个新的流程,它提供了可视化的流程表现.业务人员创建有效.流线型的业务流程让最终用户知道当前在哪.下一步要做什么,用户可以 ...

  5. contiki-main.c 中的process系列函数学习笔记 <contiki学习笔记之六>

    说明:本文依然依赖于 contiki/platform/native/contiki-main.c 文件. ---------------------------------------------- ...

  6. node学习 process笔记

    如果你是node大神好了可以关闭此页面了因为接下来游览会白白浪费你许多时间,最近一直学习node.js今晚看到 alsotang 在 github上的node教程 https://github.com ...

  7. Node.js实战项目学习系列(4) node 对象(global、process进程、debug调试)

    前言 在之前的课程我们学习了Node的模块化规则,接下来我们将学习下 Node的几个新特性:global ,process进程,debug调试 global 跟在浏览器中的window一样都是全局变量 ...

  8. Flink学习笔记:Operators之Process Function

    本文为<Flink大数据项目实战>学习笔记,想通过视频系统学习Flink这个最火爆的大数据计算框架的同学,推荐学习课程: Flink大数据项目实战:http://t.cn/EJtKhaz ...

  9. 学习动态性能表(7)--v$process

    学习动态性能表 第七篇--V$PROCESS  2007.5.30 本视图包含当前系统oracle运行的所有进程信息.常被用于将oracle或服务进程的操作系统进程ID与数据库session之间建立联 ...

随机推荐

  1. JavaBean 内省API BeanUtils工具 泛型 xml xml约束

    1 什么是JavaBean?有何特征? 1)符合特定规则的类    2)JavaBean分二类:     a)侠义的JavaBean         .私有的字段(Field)         .对私 ...

  2. Git教程(2)官方命令文档及常用命令表

    http://www.cnblogs.com/angeldevil/archive/2013/11/26/3238470.html 1,官方命令文档 http://www.git-scm.com/do ...

  3. Java开发之多线程下载和断点续传

    代码实现了多线程下载和断点续传功能 import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream ...

  4. poj 3007 Organize Your Train part II(二叉排序树)

    题目:http://poj.org/problem?id=3007 题意:按照图示的改变字符串,问有多少种..字符串.. 思路:分几种排序的方法,,刚开始用map 超时(map效率不高啊..),后来搜 ...

  5. UVa 10048 (Floyd变形) Audiophobia

    题意: 给一个带权无向图,和一些询问,每次询问两个点之间最大权的最小路径. 分析: 紫书上的题解是错误的,应该是把原算法中的加号变成max即可.但推理过程还是类似的,如果理解了Floyd算法的话,这个 ...

  6. Java 简单登录MVC

    构建一个简单的基于MVC模式的JavaWeb 零晨三点半了,刚刚几个兄弟一起出去吼歌,才回来,这应该是我大学第二次去K歌,第一次是大一吧,之后每次兄弟喊我,我都不想去,因为我还是很害怕去KTV,或许是 ...

  7. amoeba安装与实现amoeba for mysql读写分离

    运行环境 l  CentOS6.3 l  Jdk1.6.0_30 l  amoeba-mysql-binary-2.2.0 l  amoeba:192.168.88.17 l  master1:192 ...

  8. Java [Leetcode 100]Same Tree

    题目描述: Given two binary trees, write a function to check if they are equal or not. Two binary trees a ...

  9. ejabberd中的http反向推送

    http的反向推送通常使用"长轮询"或"长连接"的方式. 所谓"长轮询"是指客户端发送请求给服务器,服务器发现没有数据需要发送给客户端. h ...

  10. 可用于Hadoop下的ETL工具——Kettle

    看大家分享了好多hadoop相关的一些内容,我为大家介绍一款ETL工具——Kettle.    Kettle是pentaho公司开源的一款ETL工具,跟hadoop一样,也是java实现,其目的就是做 ...