博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
javaJVM
阅读量:6402 次
发布时间:2019-06-23

本文共 1089 字,大约阅读时间需要 3 分钟。

javaJVM

JVM是想象中的实体机器,有想象中的处理器,堆,栈,寄存器等

java虚拟机会将程序创建的对象放到堆中,栈中存放的是非static的自动变量,如函数参数,表
达式的临时结果和函数返回值(如果他们没有被放到寄存器中).栈中的这些实体数据分配和释
放都是由系统自动完成,,堆中存放的数据都是显性分配的,没有自动垃圾回收机制的系统中必
须由程序代码显示的释放这些实体.
堆的管理,不同的语言实现是不同的,如C语言就没有把分配和释放写到语言的层次,它对堆空间
对象的操作是通过其库函数malloc()和free()来实现的,而C++直接把对堆空间中的到对象分配
和释放做到语言层次, 使用new和delete语句,Java就做到跟彻底,应用开发者只要在需要堆分
配的时候创建就行了,合适释放如何释放,都有Java虚拟机(JVM)来做,而不需要程序代码来显示
地释放.
JVM有着各种版本的实现,他们基本上都会有垃圾回收(虽然没有这样的硬性规范规定),版本之
间的回收机制算法会不同.java中Object的finalize()方法,它会在垃圾回收器认为这个对象是
垃圾的之后,真正回收之前被调用.因为所有的类都继承自Object,所以他们都会有finalize()
方法.程序员可以在这个方法中写一些需要在对象被回收前做的事情,例如关闭数据库连接.
finalize()
protect void finalize() throws Throwable

一般在调用这个方法之前,垃圾回收器能检测出不在被引用的对象,如果这些对象覆盖了
finalize()芳,就要调用方法
另外,在java.lang.System类中,有一个gc()方法,他对JVM的垃圾回收也有一些影响.通过显示
的调用它可以请求开始垃圾回收线程,开始垃圾回收,但垃圾回收线程是否立即开始还是由JVM
的算法决定的
java.lang.Runtime类的gc()方法与System的作用一样,只不过Runtime是一个单例模式类,需
要调用getRuntime()方法来获得他的实例,然后才能调用gc()方法,代码如下:
    System.gc();
    Runtime.getRuntime.gc();
垃圾回收线程是一个优先级很低的线程.
java的堆内存释放功能是由垃圾回收器自动进行的,无需程序员显示调用delete()方法,可以有
效避免因为忘记释放内存造成内存溢出的错误.相比于C++是巨大改进

转载于:https://www.cnblogs.com/Hui-2017/p/6610933.html

你可能感兴趣的文章
jQuery打造智能提示插件二(可编辑下拉框)
查看>>
[Python] Python 之 function, unbound method 和 bound method
查看>>
希尔排序
查看>>
改变随机数中一些值的概率
查看>>
Spark分析之SparkContext启动过程分析
查看>>
2014电子商务安全技术峰会(含全议题下载)
查看>>
东大OJ-5到100000000之间的回文质数
查看>>
linux C 快速排序法
查看>>
模仿与创新
查看>>
Python用subprocess的Popen来调用系统命令
查看>>
Java NIO与IO的差别和比較
查看>>
.NET源代码的内部排序实现
查看>>
解决Strict Standards: Only variables should be passed by reference
查看>>
解决JBoss只能通过localhost(127.0.0.1)而不能通过IP访问
查看>>
MS SQL处理双引号(DoubleQuote)函数
查看>>
[智能架构系列]什么是Buddy智能开发框架
查看>>
三十一、关于android camera setParameters出错
查看>>
【收藏】QCIF、 CIF、2CIF、DCIF、D1(4CIF)格式介绍
查看>>
hdu 3836 Equivalent Sets (tarjan缩点)
查看>>
一些iOS高效开源类库(转)
查看>>