您的位置:首页 > 其它

进程和线程的区别

2015-09-23 13:49 260 查看
网上看到的一个比较好的文章,转载一下:

——————————————————————————————————————————————————————————————————

这个问题,貌似很简单,但要回答好,却不是那么简单。以下总结下怎么回答这个问题。

step 1:解释进程和线程的概念

进程:a process is an instance of a computer
program that is being executed. A computer program is a passive collection of instructions; a process is the actual execution of those instructions.Depending on theoperating
system (OS), a process may be made up of multiple threads of execution that
execute instructionsconcurrently.[1][2]引自wiki

翻译:进程是正在执行的程序的实例。程序只是消极的指令的集合,进程才是指令的真实的执行过程。进程往往由多个并发执行指令的线程组成。

线程:a thread of execution is the smallest unit of processing that can be scheduled by
an operating system ,Multiple threads can exist within the same process and share resources
such as memory 引自wiki

翻译:线程是操作系统调度的最小的执行单元,多个线程存在于同一个进程中,并共享进程的资源。



step2:简单说下进程和线程的关键不同点

1.同一个进程的多个线程共享内存空间,所以线程之间的通信非常方便。而不同进程因为有各自不同的虚拟空间,所以要进行进程的通信必须采取IPC机制

2.同时,因为线程共享内存空间,所以线程之间需要有好的线程同步的机制,拥有线程的程序会比较复杂。而不同的进程因为地址空间不同,所以相对来说安全。

3.进程是资源分配的基本单位,是一个资源的集合体,线程是CPU调度的最小的单元。

4.线程是轻量级的进程,创建线程和切换线程代价小,适合于并发环境中。

——————————————————————————————————————————————————————————————————

最后还有人打了一个通俗的比方:

一个系统运行着很多进程,可以比喻为一条马路上有很多马车

不同的进程可以理解为不同的马车

而同一辆马车可以有很多匹马来拉------这些马就是线程

假设道路的宽度恰好可以通过一辆马车

道路可以认为是临界资源

那么马车成为分配资源的最小单位(进程)

而同一个马车被很多匹马驱动(线程)-----即最小的运行单位

每辆马车马匹数=1

所以马匹数=1的时候进程和线程没有严格界限,只存在一个概念上的区分度

马匹数大于1的时候才可以严格区分进程和线程
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: