关于JVM(虚拟机)

(1).基本概念
JVM是可运行Java代码的假象计算机,包括一套字节码指令集、一组寄存器、一个栈、一个堆、一个垃圾回收,和一个存储方法域。JVM是运行在操作系统之上的,它与硬件没有直接的交互。
(2).运行过程
我们都知道Java源文件,通过编译器,能够产生相应的class文件,也就是字节码文件,而字节码文件又通过Java虚拟机中的解释器,编译成特定机器上的机器码。详细如下:
①Java源文件–>编译器–>字节码文件
②字节码文件–>JVM(解释器)–>机器码(二进制)
每一种平台的解释器是不同的,但是实现的虚拟机是相同的,这也就是Java为什么能够跨平台的深一层次原因了。当一个程序从开始运行,这是虚拟机就开始实例化了,多个程序启动就会存在多个虚拟机实例,程序退出或者关闭,相应的,虚拟机实例消亡,多个虚拟机实例之间数据不能共享。
(3)JVM内存区域
JVM内存区域主要分为线程私有区域【程序计数器,虚拟机栈、本地方法区】、线程共享区域【JAVA堆 、方法区】、直接内存。
线程私有区域生命周期与线程相同,依赖用户线程的启动/结束 而创建/销毁,每个线程都与操作系统的本地线程直接映射,因此这部分内存区域的存在与否跟本地线程的生与死相对应。
线程共享区域随虚拟机的启动/关闭 而创建/销毁。
直接内存并不是JVM运行时数据区的一部分,但也会被频繁的使用:在JDK1.4引入的NIO提供了基于Channel(通道)与Buffer(缓存)的IO方式,它可以使用Native函数库直接分配堆外内存,然后使用DirectByteBuffer对象作为这块内存的引用进行操作,这样就避免了在Java堆和Native堆中来回复制数据,进而提高性能。
(4)JVM运行时内存
Java堆从GC(垃圾回收机制)的角度还可分为新生代、老生代、永久代。具体详情,请搜索垃圾回收机制详解。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值