深入理解 jvm实例、程序、进程、线程的关系。

  • Post author:
  • Post category:其他


参考文章:

https://blog.csdn.net/u013467442/article/details/60323541


https://blog.csdn.net/zhangjg_blog/article/details/20380971


https://books.google.co.jp/books?id=3E6U06NhnYEC&pg=PA71&lpg=PA71&dq=%E4%B8%80%E4%B8%AA%E7%A8%8B%E5%BA%8F%E8%87%B3%E5%B0%91%E6%9C%89%E5%A4%9A%E4%B8%AA%E8%BF%9B%E7%A8%8B&source=bl&ots=H3dNM9lM9k&sig=STQb9OuViTPkNNWKGbXBD_49HWM&hl=zh-CN&sa=X&ved=0ahUKEwj9jYrwr4rbAhXEH5QKHU0LBHQQ6AEITTAE#v=onepage&q=%E4%B8%80%E4%B8%AA%E7%A8%8B%E5%BA%8F%E8%87%B3%E5%B0%91%E6%9C%89%E5%A4%9A%E4%B8%AA%E8%BF%9B%E7%A8%8B&f=false

(71页)

理解的结论:


一个进程可以拥有多个线程。


一个程序可以有多个进程(多次执行,也可以没有进程,不执行)


一台机器上可以有多个JVM实例(也可以没有JVM实例)


进程是指一段正在执行的程序


线程是程序执行的最小单位。


通过多次执行一个程序可以有多个进程,通过调用一个进程可以有多个程序。

程序运行时,会首先建立一个JVM实例———-所以说,JVM实例是多个的,

每个运行的程序对应一个JVM实例

。每个java程序都运行在一个单独的JVM实例上,(new创建实例,存放在堆空间),所以说

一个java程序的多个线程,共享堆内存


什么是进程?




总的来说,操作系统的执行单元是进程,每一个JVM实例就是一个进程,而在该实例上运行的主程序是一个主线程(可以看成一个轻量级的进程),该程序下还存在很多线程。


事实上在执行java程序时,我们注意到命令行为“java xxx”,其实java就是实例化jvm实例的命令。所以当一个程序中调用了另一个程序时,并没有再次加载一个新的JVM实例,只是认为调用了一个方法而已。





版权声明:本文为Noreaday原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。