Java垃圾回收器

[url]http://blog.csdn.net/ForWayfarer/archive/2008/03/11/2171025.aspx[/url]
Java语言中一个显著的特点就是引入了垃圾回收机制,使c++程序员最头疼的内存管理的问题迎刃而解,它使得Java程序员在编写程序的时候不再需要考虑内存管理。
由于有个垃圾回收机制,Java中的对象不再有“作用域”的概念,只有对象的引用才有“作用域”。垃圾回收可以有效的防止内存泄露,有效的使用可以使用的内存。
垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有使用的对象进行清楚和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。回收机制有分代复制垃圾回收和标记垃圾回收,增量垃圾回收。

<1> 声明的是局部变量,应该是放在在栈中的,它所指向的对象被分配在堆中,垃圾回收器只回收堆中的对象。对于你的变量在其走出作用域时,自然就释放掉了。垃圾回收的时候,通常从栈中出发,到堆中寻找垃圾对象,然后收集。

<2>在java中尽管存在垃圾回收器,但是依然会出现内存泄露的问题,这是因为在程序中可能存在垃圾回收器无法收集的持续存在的无用引用。当不再使用一个对象时,最好明确置对象为null,但这并不能控制垃圾回收器立刻工作,只是做到通知垃圾回收器有需要回收的对象。如果系统中可用的内存过低,系统也会自动运行垃圾回收器释放对象占用的内存资源供其他对象使用。

<3>Java中垃圾回不回收,什么时候回收是JVM的事,是没办法控制的。用System.gc(),只能建议JVM进行垃圾回收,但垃圾回收工作也不一定执行。
JVM只是保证你在需要内存的时候,给你内存,这是其他语言没法比拟的(个人认为是JAVA最成功的)


垃圾回收器只知道释放那些由new分配的内存。一旦垃圾回收器准备回收new对象,将首先调用finalize()方法,该方法能在垃圾回收时刻做一些清理工作。

这意味着在你不需要某个对象之前,如果必须执行某些动作,那么你得自己去做(finalize()方法)。通常不能指望finalize(),必须创建其他的"清理"方法,并且明确的调用它们。finalize()作用:对象"终结条件"的验证。

class finalizeTest...{
public static void main(String[] args)...{
Auto auto = new Auto();//当一个对象没有被引用时才会成为垃圾,这一句的new对象不是垃圾。
auto = null; //刚才的new对象成为垃圾。
new Auto();
new Auto();
System.gc();
}
}

class Auto...{
public void finalize()...{
System.out.println("Auto is going");
}
}


ps:finalize()方法放在Auto类中,则new Auto()对象回收的时候会被调用;如果finalize()方法放在finalizeTest类中,则new Auto()对象回收的时候不会被调用,new finalizeTest()对象回收的时候才会被调用。

运行结果:

Auto is going
Auto is going
Auto is going

另外一个应用实例

class Book{
public boolean checkedout = false;
public Book(boolean checkout){
checkedout = checkout;
}
public void checkIn(){
checkedout = false;//状态转换 && 将checkedout变量归位到false
}
public void finalize(){
if(checkedout)
System.out.println("这本书没有执行checkIn");
}
public static void main(String[] args){
Book ThinkingInJava = new Book(true);
ThinkingInJava.checkIn();

Book DataStructure = new Book(true);
DataStructure = null;
System.gc();
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java垃圾回收机制是Java语言的一项重要特性,它可以自动管理内存,减轻了程序员手动释放内存的负担。Java垃圾回收机制主要通过垃圾收集(Garbage Collector)来实现。 在Java中,当一个对象不再被引用时,就可以被判定为垃圾。垃圾收集会定期扫描堆内存,找出不再被引用的对象,并将其回收释放内存空间。这样,程序员就不需要手动释放对象所占用的内存,大大简化了内存管理的工作Java垃圾回收机制基于以下两个核心概念: 1. 引用计数法:每个对象都有一个引用计数,当有新的引用指向该对象时,计数加1;当引用失效时,计数减1。当计数为0时,表示该对象不再被引用,可以被回收。但是,引用计数法无法解决循环引用的问题,即两个或多个对象相互引用,但与程序的根节点没有直接引用关系,导致无法被回收。 2. 可达性分析算法:Java垃圾回收机制采用可达性分析算法来判断对象是否可被回收。该算法从程序的根节点(如静态变量、方法参数等)出发,通过引用链追踪对象的引用关系,如果一个对象不可达(即无法通过引用链与根节点相连),则被判定为垃圾,可以被回收。 Java垃圾回收机制具有以下优点: 1. 简化了内存管理,减少了内存泄漏和野指针等问题的发生。 2. 提高了程序的可靠性和稳定性,减少了因为内存管理错误导致的程序崩溃。 3. 提高了开发效率,程序员不需要手动释放内存,可以更专注于业务逻辑的实现。 然而,垃圾回收机制也存在一些缺点: 1. 垃圾回收过程会占用一定的系统资源,可能会导致程序的运行速度变慢。 2. 垃圾回收的时间是不确定的,可能会导致程序在某些时刻出现短暂的停顿。 相关问题: 1. Java垃圾回收机制是如何工作的? 2. 什么是引用计数法?它有什么缺点? 3. 什么是可达性分析算法?它如何判断对象是否可被回收? 4. 垃圾回收机制有哪些优点和缺点?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值