如何模拟jvm虚拟计算机?

查资料感觉实体计算机对jvm的虚拟模拟过程就是分给jvm一块内存,完毕!!!!!!

有这么简单?怎么感觉不能这么简单呢?

别说,还真有这种可能,虽然说“模拟计算机”的口号喊得够大,但不能傻乎乎的认为是模拟了整个计算机的物理硬件功能,而且整个模拟也不现实,都是在现有的基础上进行加工改造的:分给你一块内存独用,其他的资源跟实体计算机共用;常规这做法应该就是这样,比如CPU那么精密的东西,你要怎样通过写逻辑模拟一个全新的CPU?还不得跟实体计算机通过多线程进行共用!!!

然后,这块分配给jvm的内存分为私有和公有,规范点的说法:线程隔离的区域,线程共享的区域;

再然后就会产生这样的问题,线程共享的区域容易产生垃圾,这就要涉及到垃圾回收机制了,具体的就先不说了!

jvm内存再规范点的分类:

堆heap: 存储所有的类实例,为数组内存分配空间;堆分为:young generation 和 old generation;

           young generation: 1*(eden sapce) + 2*(Surviver space)(from、to)

                                            Eden:伊甸园     ------- 存放新生的对象(new 对象)

                                            Surviver:存活者  ------- 经历过垃圾回收后存活下来的对象

           old generation: 存放生命周期长的对象;

非堆permanent:  存储java的类信息,包括解析后得到的方法、属性、字段等;不参与垃圾回收;

感觉非堆存储一些不怎么变动的.class文件,而非堆则为程序运行做准备,再然后排队获得cpu资源运行程序;

猜你喜欢

转载自blog.csdn.net/jim_007/article/details/81083552
今日推荐