注册本站  论坛  繁體中文

电脑技巧
手机 | MP3 | MP4 | 显卡 | 主板 | 显示器 | 光存储 | 笔记本 | 网络设备 | 移动存储 | 数码相机
键鼠 | CPU | 音箱 | GPS | 电视 | 服务器 | 投影机 | 机箱电源 | 品牌电脑 | 办公打印 |
| 网站首页 | Cisco | Windows | Linux | Java | Dotnet | Oracle | 网页设计 | 平面设计 | 安全 | 软件应用 | 电脑维修 | 办公维修 |
您现在的位置: 电脑技巧 >> Java >> 核心技术 >> 高级编程 >> Java正文

关于java递归调用内存泄漏

文章来源:中国IT实验室整理 作者:佚名 更新时间:2008-8-23 14:36:39 【 】 【加入收藏

    看两段代码:

import java.util.ArrayList;   
import java.util.List;   
  
public class TailRecursionTest {   
    public static void main(String[] args) {   
        TailRecursionTest t = new TailRecursionTest();   
        for (int i = 0; i < 10000; i++)   
            t.a(0);   
    }   
  
    public void a(int j) {   
        j++;   
        List list = new ArrayList<Integer>(100000);   
        // 对list进行处理   
    }   
}
    没啥特殊的,仅仅是为了测试,我们将a方法调用10000次,a方法创建一个有100000个元素的list的局部变量。
    第二个程序:
import java.util.ArrayList;   
import java.util.List;   
  
public class TailRecursionTest2 {   
    public static void main(String[] args) {   
        TailRecursionTest2 t = new TailRecursionTest2();   
        t.a(0);   
    }   
  
    public void a(int j) {   
        System.out.println(j);   
        j++;   
        if (j == 10000)   
            return;   
        List list = new ArrayList<Integer>(100000);   
        // 对list进行处理   
        a(j);   
    }   
}  
    也没啥特殊的,就是将循环换成了递归,a方法做的事情没变。两个都跑一下,程序1顺利结束,程序2出问题了,啥问题?如下:
161  
162  
163  
164  
165  
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space   
    at java.util.ArrayList.<init>(Unknown Source)   
    at TailRecursionTest2.a(TailRecursionTest2.java:17)   
    at TailRecursionTest2.a(TailRecursionTest2.java:20)   
    at TailRecursionTest2.a(TailRecursionTest2.java:20)   
    at TailRecursionTest2.a(TailRecursionTest2.java:20)   
    at TailRecursionTest2.a(TailRecursionTest2.java:20) 

 

  • 上一篇Java:

  • 下一篇Java: 没有了
  • 最 新 热 门
     Flash、HTML、Ajax 谁将赢得Web应用之战
     超越XML和JSON:YAML,Java开发人员的新选择
     优秀Java程序员必须了解的GC工作原理
     Java 6 RowSet 使用完全剖析
     pureQuery带注释的方法风格简介
     面向Java开发人员的Scala指南: 实现继承
     Java 6中的性能优化
     Java实现Windows的dir命令
     Java标准类库提供的容器总结
     在Tomcat上开发Web应用如何保证兼容性
    最 新 推 荐
     关于java递归调用内存泄漏
     JBuilder 用户 NetBeans IDE 指南
     现代Java Web开发架构分析
     防止java反编译的一些常用方法
     java技巧之时间计算
     Java中国象棋博弈程序探秘之游戏与界面
     简单的日历表写法
     java关于split分割字符串 空字符串不能得到…
     Java中国象棋博弈程序探秘之搜索算法
     Java中国象棋博弈程序探秘之生成有效着法
    相 关 文 章

    Flash、HTML、Ajax 谁将赢得Web应用之战
    超越XML和JSON:YAML,Java开发人员的新选择
    优秀Java程序员必须了解的GC工作原理
    Java 6 RowSet 使用完全剖析
    面向Java开发人员的Scala指南: 实现继承
    Java 6中的性能优化
    Java实现Windows的dir命令
    Java标准类库提供的容器总结
    关于tomcat快速启动及自动重启的方法与脚本
    在Eclipse中用Java实现百灵报表(BIRT)的事件…

    | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告

     

    Copyright 2006-2008 pcjx.com All Rights Reserved
    电脑技巧 版权所有 粤ICP备06059145号 地图
    本网站所有内容未经许可不得转载或做其他使用