Java千百问_01基本概念(006)_线程和进程有什么区别

来源:互联网 发布:邮箱大师mac版本下载 编辑:程序博客网 时间:2024/05/02 05:02

点击进入_更多_Java千百问

1、进程是什么

进程(process)是具有一定独立功能的程序,操作系统利用进程把工作划分为一些功能单元

进程是进行资源分配调度的一个独立单位。它还拥有一个私有的虚拟地址空间,该空间仅能被它所包含的线程访问。

一个应用程序(application)是由一个或多个相互协作的进程组成的。例如,Visual Studio开发环境就是利用一个进程编辑源文件,并利用另一个进程完成编译工作的应用程序。

2、线程是什么

线程(thread)是进程中所包含的一个或多个执行单元。它只能归属于一个进程并且只能访问该进程所拥有的资源。
它进程中执行运算的最小单位,是进程中的一个实体,是被进程独立调度分派的基本单位。

线程自己不拥有系统资源,只拥有一点在运行中必不可少的资源(计数器、寄存器和栈),但它可与同属一个进程的其它线程共享进程所拥有的全部资源。一个线程可以创建和撤消另一个线程,同一进程中的多个线程之间可以并发执行

当操作系统创建一个进程后,该进程会自动申请一个名为主线程(首要线程)的线程。主线程将执行运行时宿主,而运行时宿主会负责载入CLR(公共语言运行库)。

3、线程和进程有什么关系以及区别?

首先,进程和进程如同列车和车厢,没有可比性,但是他们有一定的相关性:

  1. 一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
  2. 资源分配给进程,同一进程的所有线程共享该进程的所有资源。
  3. 虚拟机分给线程,即真正在虚拟机上运行的是线程
  4. 线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。

如果非要比较进程与线程的区别,可以从以下几个方面来看:

  1. 调度
      线程作为调度和分配的基本单位,进程作为拥有资源的基本单位

  2. 并发性
      不仅进程之间可以并发执行,同一个进程的多个线程之间也可并发执行

  3. 拥有资源
      进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源.

  4. 系统开销
      在创建或撤消进程时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创建或撤消线程时的开销。

2 1