这是一个简单的集合代码:
[code="java"]
import java.util.ArrayList;
import java.util.List;
public class Test {
public static void main(String[] args) {
List list = new ArrayList();
for(int i=0;i try{
list.add(i);
}catch(Exception e){
e.printStackTrace();
}
}
}
}
[/code]
嗯,有点经验的人一看就知道问题了——“Exception in thread "main" java.lang.OutOfMemoryError: Java heap space”,但是我稍微做个小改,居然能运行好久好久啊。。。看!
[code="java"]
import java.util.ArrayList;
import java.util.List;
public class Test {
public static void main(String[] args) {
List list = new ArrayList();
for(int i=0;i<Integer.MAX_VALUE;i++){
try{
list.add(i);
/**就加了这一句啊*/
System.out.println(list.size());
/**就加了这一句啊*/
}catch(Exception e){
e.printStackTrace();
}
}
}
}
[/code]
我用的是JDK1.6,开发工具是Eclipse,我一开始还以为是Eclipse的问题,然后我直接命令行运行,javac Test.java java Test
结果还是一样的。。。这是为什么啊?只加了一句输出情况就大不一样了???
因为在执行System.out.println(list.size()); 会像控制台打印,除了占用一点系统资源还有会频繁刷屏,占用更多的cpu,所以导致整体运行时间翻翻。机器配置越低,效果越明显。
第二个能运行好久好久,是因为System.out.println(),多了个向控制台打印的动作,当然比单独的list.add()耗时了,当占满对内存之前当然运行的时间长了
想知道第二个究竟输出打印耗了多长时间,Integer的最大值怎么数得来哦。