深入理解程序、 jvm实例、进程、线程的关系
- 问题引出
- 实验
- 进程的概念
- 线程的概念
- 结论
问题引出
命令启动了两个java程序,它们之间是什么关系?
java程序又和JVM之间是什么关系,它们是共用一个JVM,还是每个java程序,都有一个JVM?
进程和程序是什么关系,进程和线程是什么关系?
实验
用命令启动两个一样的java程序。
#java HelloWorld
用jvisual观察到有两个HelloWorld程序的进程。
进程的概念
在多道程序工作的环境下,操作系统必须能够实现资源的共享和程序的并发执行,从而使程序的执行出现了并行、动态和相互制约的新特征。 为了能反映程序活动的这些新特点, UNIX 引入了进程( process)这个概念。 UNIX的进程是一个正在执行的程序的映象。 这里需要注意的是程序和进程的区别。一个程序是一个可执行的文件,而一个进程则是一个执行中的程序实例。 在UNIX/Linux系统中可以同时执行多个进程(这一特征有时称为多任务设计),对进程数目无逻辑上的限制,并且系统中可以同时存在一个程序的多个实例。 各种系统调用允许进程创建新进程、终止进程、对进程执行的阶段进行同步及控制对各种事件的反映。在进程使用系统调用的条件下,进程便相互独立的执行了。 因为一个进程对应于一个程序的执行,所以绝对不要把进程与程序这两个概念相混淆。进程是动态的概念,而程序为静态的概念。实际上,多个进程可以并发执行同一个程序。
线程的概念
一个服务器通常需要接收大量且不确定数量用户的并发请求,为每一个请求都创建一个进程显然是行不通的,——无论是从系统资源开销方面或是响应用户请求的效率方面来看。因此,操作系统中线程的概念便被引进了。线程,是进程的一部分。线程有时又被称为轻权进程或轻量级进程,也是 CPU 调度的一个基本单位。线程之间共用一个进程的内存空存空间(即jvm堆内存),各个线程也有自己独立专有的内存空间(即jvm栈空间)。
结论
(1)JVM是一份本地化的程序,本质上是可执行的文件,是静态的概念。程序运行起来成为进程,是动态的概念。
(2) java程序是跑在JVM上的,严格来讲,是跑在JVM实例上的,一个JVM实例其实就是JVM跑起来的进程,二者合起来称之为一个JAVA进程。
(3)各个JVM实例之间是相互隔离的。
(4)一般一个进程是一个java程序的实例。
- 进程:是并发执行的程序在执行过程中分配和管理资源的基本单位。
- 线程:线程有时又被称为轻权进程或轻量级进程,也是 CPU 调度的一个基本单位。线程之间共用一个进程的内存空存空间(即jvm堆内存),各个线程也有自己独立专有的内存空间(即jvm栈空间)。