CPU进程与线程的关系和区别_第1页
CPU进程与线程的关系和区别_第2页
CPU进程与线程的关系和区别_第3页
CPU进程与线程的关系和区别_第4页
CPU进程与线程的关系和区别_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、CPU 进程与线程的关系和区别篇一:进程和线程的区别进程和线程的区别 线程是指进程内的一个执行单元 ,也是进程内 的可调度实体 .与进程的区别 :地址空间 :进程内的一个执行单元 ;进程至少有一个线程;它们 共享进程的地址空间 ;而进程有自己独立的地址空间 ; TOC o 1-5 h z 资源拥有 :进程是资源分配和拥有的单位, 同一个进程内的线程共享进程的资源线程是处理器调度的基本单位 ,但进程不是.4)二者均可并发执行. 进程和线程都是由操作系统所体会的程序运行的基本单元,系统 利用该基本单元实现系统对应用的并发性。进程和线程的区别在于: 简而言之 ,一个程序至少有一个进程,一个进程至少有

2、一个线程.线程的划分尺度小于进程,使得多线程程序的并发性高。另外, 进程在执行过程中拥有独立的内存单元, 而多个线程共享 内存,从而极大地提高了程序的运行效率。线程在执行过程中与进程还是有区别的。 每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执 行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的 重要区别。进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动 , TOC

3、 o 1-5 h z 进程是系统进行资源分配和调度的一个独立单位.线程是进程的一个实体, 是 CPU 调度和分派的基本单位 , 它是比进 程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只 拥有一点在运行中必不可少的资源( 如程序计数器,一组寄存器和栈) ,但 是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.一个线程可以创建和撤销另一个线程 ;同一个进程中的多个线程之间可以并发执行.和 stdio.h 区别#includestdio.h 当要调用某个函数时先在用户自已编写的文件中查找, 如果找不到再到库文件里去找, 而#“elude 是直接到库文件里去找所以如果是调用自己

4、写的函数的话就用 #includestdio.h , 这种形 式而调用标准库函数的话就用 #include 这种形式,可以提高速度篇二:进程线程区别与联系定义:程序只是一组指令的有序集合二 进程是具有一定独立功能的程序关于某个数据集合上的一次 运行活动,是系统进行资源分配和调度的一个独立单位;三 线程是进程的一个实体,是 CPU 调度和分派的基本单位 ,它是 比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源 只拥有一点在运行中必不可少的资源( 如程序计数器,一组寄存器和栈 ), 一个线程可以创建和撤销另一个线程;一 进程与线程区别与联系划分尺度:线程更小,所以多线程程序并发性更高

5、;资源分配:进程是资源分配的基本单位,同一进程内多个线程共享其资源;地址空间:进程拥有独立的地址空间,同一进程内多个线程共享其资源;处理器调度:线程是处理器调度的基本单位;执行:每个线程都有一个程序运行的入口,顺序执行序列和 程序的出口, 但线程不能单独执行, 必须组成进程, 一个进程至少有 一个主线程。简而言之 ,一个程序至少有一个进程,一个进程至少有一个线程 .二 进程和程序区别和联系(1) 程序只是一组指令的有序集合, 它本身没有任何运行的含义, 它只是一个静态的实体。而进程则不同,它是程序在某个数据集上的 执行。进程是一个动态的实体,它有自己的生命周期。反映了一个程 序在一定的数据集上

6、运行的全部动态过程。2 ) 进程和程序并不是一一对应的,一个程序执行在不同的数据集上就成为不同的进程,可以用进程控制块来唯一地标识每个进程。 而这一点正是程序无法做到的, 由于程序没有和数据产生直接的联系, 既使是执行不同的数据的程序,他们的指令的集合依然是一样的,所 以无法唯一地标识出这些运行于不同数据集上的程序。一般来说,一 个进程肯定有一个与之对应的程序,而且只有一个。而一个程序有可 能没有与之对应的进程 ( 因为它没有执行) ,也有可能有多个进程与之对应(运行在几个不同的数据集上 ) 。3 ) 进程还具有并发性和交往性,这也与程序的封闭性不同。 进程和程序区别和联系表现在以下方面:)

7、程序只是一组指令的有序集合,它本身没有任何运行的含义, 它只是一个静态的实体。而进程则不同,它是程序在某个数据集上的执行。进程是一个动态的实体, 它有自己的生命周期。 它因创建而产生, 因调度而运行,因等待资源或事件而被处于等待状态,因完成任务而被撤消。反映了一个程序在一定的数据集上运行的全部动态过程。) 进程和程序并不是一一对应的,一个程序执行在不同的数据集上就成为不同的进程,可以用进程控制块来唯一地标识每个进程。而 这一点正是程序无法做到的,由于程序没有和数据产生直接的联系,既使是执行不同的数据的程序,他们的指令的集合依然是一样的,所以无法唯一地标识出这些运行于不同数据集上的程序。一般来说

8、,一 个进程 肯定有一个与之对应的程序,而且只有一个。而一个程序有可 能没有与之对应的进程( 因为它没有执行) ,也有可能有多个进程与之对应 ( 运行在几个不同的数据集上 ) 。) 进程还具有并发性和交往性,这也与程序的封闭性不同。进程和线程都是由操作系统所体会的程序运行的基本单元,系统利用该基本单元实现系统对应用的并发性。进程和线程的区别在于:简而言之 ,一个程序至少有一个进程,一个进程至少有一个线程. 线程的划分尺度小于进程,使得多线程程序的并发性高。 另外,进程在执行过程中拥有独立的内存单元,而多个线程共享 内存,从而极大地提高了程序的运行效率。线程在执行过程中与进程还是有区别的。 每个

9、独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执 行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的 应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的 重要区别。进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动 ,进程是系统进行资源分配和调度的一个独立单位 .线程是进程的一个实体, 是 CPU 调度和分派的基本单位 , 它是比进 程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只 拥有一点在运行中必不可少的

10、资源( 如程序计数器,一组寄存器和栈 ) ,但 是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.一个线程可以创建和撤销另一个线程 ; 同一个进程中的多个线程之间可以并发执行.作业进程程序之间的联系程序与进程之间的区别:1)进程更能真实地描述并发,而程序不能。2)进程由程序和数据两部分组成,进程是竞争计算机系统有限资源的基本单位,也是进程处理机调度的基本单位。3)程序是静态的概念;进程是程序在处理机上一次执行的过程,是动态的概念。4 )进程有生存周期,有诞生有消亡。是短暂的;而程序是相对长久的。5 )一个程序可以作为多个进程的运行程序;一个进程也可以运行多个程序。( 6 ) 进程具有创

11、建其他进程的功能;而程序没有。 作业与进程的区别: TOC o 1-5 h z 一个进程是一个程序对某个数据集的执行过程, 是分配资源的基本单位。作业是用户需要计算机完成的某项任务,是要求计算机所做工作的集合。一个作业的完成要经过作业提交、作业收容、作业执行和作业完成 4 个阶段。 而进程是对已提交完毕的程序所执行过程的描述,是资源分配的基本单位。其主要区别如下。( 1 )作业是用户向计算机提交任务的任务实体。在用户向计算机提交作业后,系统将它放入外存中的作业等待队列中等待执行。而 进程则是完 成用户任务的执行实体,是向系统申请分配资源的基本单 位。任一进程,只要它被创建,总有相应的部分存在于

12、内存中。( 2 )一个作业可由多个进程组成,且必须至少由一个进程组成, 反过来则不成立。( 3 )作业的概念主要用在批处理系统中,像UNIX 这样的分时系 统中就没有作业的概念。而进程的概念则用在几乎所有的多道程序系 统中。作业、进程和程序之间的联系: 一个作业通常包括程序、数据和操作说明书 3 部分。每一个进程由 PCB 程序和数据集合组成。这说明程序是进程的一部分,是进程的 实体。因此,一个作业可划分为若干个进程来完成,而每一个进程有其实体 程序和数据集合。篇三:线程与进程有什么区别? 简单的说,你每启动一个程序,就启动了一个进程。 在 Windows 3.x 下, 进程是最小运行单位。

13、在 Win dows 95/NT下,每个进程还可以启动几个线程, 比如每下载一个文件可以单独开一个线程。 在 Windows95/NT 下,线程是最小单位。 WINDOWS 的多任务特性使得线程之间独 立运行,但是它们彼此共享虚拟空间,也就是共用变量,线程有可能 会同时操作一片内存。什么是系统的进程? 发布: 狱火华衣 分类: 进程知识 发布日 期:2005.08.21下面针对 hejb 的提问, 我先让朋友们了解一下在任务管理器里的 进程。其实在谈到进程时,还要涉及到线程的概念。 进程是指在系统 中正在运 行的一个应用程序; 线程是系统分配处理器时间资源的基本 单元,或者说进程之内独立执行的

14、一个单元。对于操作系统而言,其 调度单元是线程。一个进程至少包括一个线程,通常将该线程称为主 线程。一个进程从主线程的执行开始进而创建一个或多个附加线程, 就是所谓基于多线程的多任务。那进程与线程的区别到底是什么?进程是执行程序的实例。 例如,当你运行记事本程序( Nodepad )时,你就创建了一个用来容纳组成Notepad.exe 的代码及其所需调用动态链接库的进程。每个进程均运行在其专用且受保护的地址空间内。因此,如果你同时运行记事本的两个拷贝,该程序正在使用的数据在各自实例中是彼此独立的。 在记事本的一个拷贝中将无法看到该程序的第二个实例打开的数据。我这里以沙箱为例进行阐述。一个进程就

15、好比一个沙箱。线程就如同沙箱中的孩子们。孩子们在沙箱子中跑来跑去,并且可能将沙子攘到别的 孩子眼中,他们会互相踢打或撕咬。但是,这些沙箱略有不 同之处就在于每个沙箱完全由墙壁和顶棚封闭起来,无论箱中的孩子 如何狠命地攘 沙,他们也不会影响到其它沙箱中的其他孩子。因此, 每 个进程就象一个被保护起来的沙箱。未经许可,无人可以进出。实际上线程运行而进程不运行。 两个进程彼此获得专用数据或内 存的唯一途径就是通过协议来共享内存块。这是一种协作策略。下面 让我们分析一下任务管理器里的进程选项卡。这里的进程是指一系列进程, 这些进程是由它们所运行的可执行 程原因。请序实例来识别的,这就是进程选项卡中的第

16、一列给出了映射名称的例的注意,这里并没有进程名称列。进程并不拥有独立于其所归属实映射名称。换言之,如果你运行5 个记事本拷贝,你将会看到 5 个称为Notepad.exe 的进程。它们是如何彼此区别的呢?其中一种方式是通过它们的进程ID, 因为每个进程都拥有其独一无二的编码。该进程 ID 由 Win dows NT 或 Win dows 2000 生成,并可以循环使用。因此,进程 ID 将不会越编越大,它们能够得到循环利用。第三列是被进程中的线程所占用的 CPU 时间百分比。它不是CPU 的编号,而是被进程占用的 CPU 时间百分比。此时我的系统基本上是 空闲的。尽管 系统看上去每一秒左右都只

17、使用一小部分CPU 时间,但 该系统空闲进程仍旧耗用了大约 99% 的 CPU 时间第四列, CPU 时间,是 CPU 被进程中的线程累计占用的小时、分钟及秒数。请注意,我对进程中的线程使用占用一词。这并不一定意 味着那就是 进程已耗用的 CPU 时间总和,因为,如我们一会儿将看到 的, NT 计时的方式是,当特定的时钟间隔激发时,无论谁恰巧处于当 前的线程中,它都将计算到 CPU 周期之内。通常情况下,在大多数NT 系统中,时钟以 10 毫秒的间隔运行。每 10 毫秒 NT 的心脏就跳动 一下。有一些驱动程序代码片段运行并显示谁是当前的线程。让我们将CPU 时间的最后 10 毫秒 记在它的帐

18、上。因此,如果一个线程开始运行,并在持续运行8 毫秒 后完成,接着,第二个线程开始运行并持续了 2 毫秒,这时,时钟激发,请猜一猜这整整 10 毫秒的时钟周期到底记在了哪个线程的帐上?答案是第 二个线程。因此, NT 中存在一些固有的不准确性,而NT 恰是以这种 方式进行计时,实际情况也如是,大多数32 位操作系统中都存在一个基于间隔的计时机 制。请记住这一点,因为,有时当你观察线程所耗用的 CPU 总和时,会出现尽管该线程或许看上去已运行过数十万次, 但其 CPU 时间占用量却可能是零或非常短暂的现象,那么,上述解释便是原因所在。上述也就是我们在任务管理器的进程选项卡中所能看 到的基本信息列。说到这里 ,我想大家对进程有一定的认识了吧 ,最后我对平时见到的各进程项细述一下,有哪些是能关的,有哪些是不能关的 .最基本的系统进程(也就是说,这些进程是系统运行的基本条件, 有了这些进程,系统就能正常运行) :smss.exe Session Managercsrss.exe 子系统服务器进程winlogon.exe 管理用户登录services.exe 包含很多系统服务lsass.exe 管理 IP 安全策略以及启动 ISAKMP/Oakley (IKE) 和

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论