java架构-线程和进程的区别

1,277 阅读2分钟

1、进程是什么

进程(process)是具有一定独立功能的程序,操作系统利用进程把工作划分为一些功能单元。 进程是进行资源分配和调度的一个独立单位。它还拥有一个私有的虚拟地址空间,该空间仅能被它所包含的线程访问。 一个应用程序(application)是由一个或多个相互协作的进程组成的。例如,Visual Studio开发环境就是利用一个进程编辑源文件,并利用另一个进程完成编译工作的应用程序。

2、线程是什么

线程(thread)是进程中所包含的一个或多个执行单元。它只能归属于一个进程并且只能访问该进程所拥有的资源。 它进程中执行运算的最小单位,是进程中的一个实体,是被进程独立调度和分派的基本单位。 线程自己不拥有系统资源,只拥有一点在运行中必不可少的资源(计数器、寄存器和栈),但它可与同属一个进程的其它线程共享进程所拥有的全部资源。一个线程可以创建和撤消另一个线程,同一进程中的多个线程之间可以并发执行。 当操作系统创建一个进程后,该进程会自动申请一个名为主线程(首要线程)的线程。主线程将执行运行时宿主,而运行时宿主会负责载入CLR(公共语言运行库)。

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

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

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

如果非要比较进程与线程的区别,可以从以下几个方面来看:
  • 调度
线程作为调度和分配的基本单位,进程作为拥有资源的基本单位
  • 并发性
不仅进程之间可以并发执行,同一个进程的多个线程之间也可并发执行
  • 拥有资源
进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源.
  • 系统开销
在创建或撤消进程时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创建或撤消线程时的开销。