尝试解答java内存问题
在园子中看见了这个园友的问题,高手指点一下,关于编写Java程序让Jvm崩溃,恰巧这两天看了点相关的东西,也尝试了一下,下面是仁兄提出的第一个疑问,我来复现一下:
package jvm; public class Crash { public static void main(String[] args) {
// Object[] o = {“abc”};初始值赋值,不会有影响。
Object[] o = null; while (true) {
o = new Object[] { o };
// 输出的话,jvm就不会崩溃。
// System.out.println(o);
}
}
}
如果我直接运行这个程序,等了好久也没有出现下面的异常,因为什么和那个兄台的结果不一样,答案很简单就是我们的环境不一样,jvm的运行参数也不一样:
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at jvm.Crash.main(Crash.java:10)
下面看一下在我执行这段代码什么都不加的情况下的jps的监控信息:
C:\Users\Think>jps -v
7888 org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar -Dosgi.requiredJavaVe
rsion=1.6 -Xms40m -Xmx512m -XX:MaxPermSize=256m
7772 Jps -Dapplication.home=E:\Program Files\Java\jdk1.7.0_40 -Xms8m
7108 Crash -Dfile.encoding=UTF-8
其中这条记录7108 Crash -Dfile.encoding=UTF-8就是我们执行的程序,在下面也看到了有4个垃圾回收的线程在进行内存回收,并没有指定heap和stack的大小,使用的都是默认值,我觉得我可以用这个程序出抛出stack和heap的异常,下面我把虚拟机运行的堆的参数改小了,改成5M吧:具体方法查看我的这篇从内存溢出看Java 环境中的内存结构。
执行,出现了如下问题,
Exception in thread "main" java.lang.OutOfMemoryError: GC overhead limit exceeded
at jvm.Crash.main(Crash.java:10)
可以在sun的网站上找到这个Bug的原因以及解决办法:http://www.oracle.com/technetwork/java/javase/gc-tuning-6-140523.html,大概意思就是我花了太多的时间(98%),但是回收的垃圾太少了(2%)。
he concurrent collector will throw an OutOfMemoryError if too much time is being spent in garbage collection: if more than 98% of the total time is spent in garbage collection and less than 2% of the heap is recovered, an OutOfMemoryError will be thrown. This feature is designed to prevent applications from running for an extended period of time while making little or no progress because the heap is too small. If necessary, this feature can be disabled by adding the option -XX:-UseGCOverheadLimit to the command line.
加上-XX:-UseGCOverheadLimit参数以后通过jps命令查看参数:
出现:
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at jvm.Crash.main(Crash.java:10)
加上输出语句以后代码如下:
public class Crash { public static void main(String[] args) {
// Object[] o = {“abc”};初始值赋值,不会有影响。
Object[] o = null; while (true) {
o = new Object[] { o };
// 输出的话,jvm就不会崩溃。
System.out.println(o);
}
}
}
再次执行程序,参数没有变化,结果依然出现异常:
[Ljava.lang.Object;@72e0726b
[Ljava.lang.Object;@63c6472d
[Ljava.lang.Object;@5c71c17e
[Ljava.lang.Object;@786aa48e
[Ljava.lang.Object;@437f3fe
[Ljava.lang.Object;@725d61a4
[Ljava.lang.Object;@402b2861
[Ljava.lang.Object;@94dc811
[Ljava.lang.Object;@7e6d0650
[Ljava.lang.Object;@4d5f4924
[Ljava.lang.Object;@20c88c8a
[Ljava.lang.Object;@57d74d5f
[Ljava.lang.Object;@3f8d2560
[Ljava.lang.Object;@1b663c05
[Ljava.lang.Object;@2046942e
[Ljava.lang.Object;@184bcffd
[Ljava.lang.Object;@1b97d23c
[Ljava.lang.Object;@6207775d
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at java.util.Arrays.copyOfRange(Unknown Source)
at java.lang.String.<init>(Unknown Source)
at java.lang.Integer.toUnsignedString(Unknown Source)
at java.lang.Integer.toHexString(Unknown Source)
at java.lang.Object.toString(Object.java:237)
at java.lang.String.valueOf(Unknown Source)
at java.io.PrintStream.println(Unknown Source)
at jvm.Crash.main(Crash.java:12)
输出的时候将上面的日志内容省略了一部分。接下来是第二个例子,要知道在堆中保存的是对象的实例,在例子中:
JvmBean j = null;
while (true) {
j = new JvmBean(j);
// 无论输出不输出,jvm都会崩溃
// System.out.println(j);
}
很显然和第一个Object的例子不一样,看着JbmBean的定义:
package jvm; public class JvmBean { JvmBean bean = new JvmBean(this); public JvmBean(JvmBean bean){
this.bean = bean;
}
}
就知道这个程序跟门就没有循环,在第一次进到循环的时候就挂了。// System.out.println(j);这句根本就执行不到。OK,我帮你修改一下:把Jvm类改为如下:
public class JvmBean {
JvmBean bean = null; public JvmBean(JvmBean bean) {
System.out.println(1);
this.bean = bean;
}
}
然后改一下JVM的运行参数:
运行结果如下:
public class JvmBean {
JvmBean bean = null; public JvmBean(JvmBean bean) {
System.out.println(1);
this.bean = bean;
}
}
所以我猜测你在第二个例子自己写的类中抛出的异常应该不是你想象中的场景。
收拾收拾回家,希望能解答你的疑惑。
尝试解答java内存问题的更多相关文章
- JMM(java内存模型)
What is a memory model, anyway? In multiprocessorsystems, processors generally have one or more laye ...
- Java 内存管理
java 内存管理机制 JAVA 内存管理总结 java 是如何管理内存的 Java 的内存管理就是对象的分配和释放问题.(两部分) 分配 :内存的分配是由程序完成的,程序员需要通过关键字 new 为 ...
- java 内存模型
翻译自wiki百科:https://en.wikipedia.org/wiki/Java_memory_model 没找到直接在wiki上编辑中文的页面,我就在这翻译下,自己学习用. java内存模型 ...
- 【深入Java虚拟机】之一:Java内存模型与内存溢出
[深入Java虚拟机]之:Java内存区域与内存溢出 高速缓存模型如下: ----------------------------------------------------分割线-------- ...
- java内存管理机制
JAVA 内存管理总结 1. java是如何管理内存的 Java的内存管理就是对象的分配和释放问题.(两部分) 分配 :内存的分配是由程序完成的,程序员需要通过关键字new 为每个对象申请内存空间 ( ...
- 修复 Java 内存模型,第 1 部分——Brian Goetz
转自Java并发大师Brain Goetz:http://www.ibm.com/developerworks/cn/java/j-jtp02244/ (中文地址) http://www.ibm.co ...
- Java内存溢出详解
转自:http://elf8848.iteye.com/blog/378805 一.常见的Java内存溢出有以下三种: 1. java.lang.OutOfMemoryError: Java heap ...
- java内存模型及分块
转自:http://www.cnblogs.com/BangQ/p/4045954.html 1.JMM简介 2.堆和栈 3.本机内存 4.防止内存泄漏 1.JMM简介 i.内存模型概述 Ja ...
- java 内存 垃圾回收调优
要了解Java垃圾收集机制,先理解JVM内存模式是非常重要的.今天我们将会了解JVM内存的各个部分.如何监控以及垃圾收集调优. Java(JVM)内存模型 正如你从上面的图片看到的,JVM内存被分成多 ...
随机推荐
- 那些牛掰的 HTML5的API(二)
1:视频播放器 2:地理定位 我们的支持html5 的浏览器给我们提供一个接口(api),可以用来获取你当前的位置. 主要是通过geolocation(地理位置),对象 ,去访问硬件,来获取到经纬度. ...
- Thread 多线程 同步
当多个线程,访问同一个对象,调用同一个方法或访问同一个对象时.有时,必须保证访问的同步性.比如,一个银行信用卡账户具有5000元的信用额度.用户除具有一张主卡外,还办有多张子卡.这些卡的累计消费金额, ...
- 【CF #313】
B题为啥交换一下搜索顺序就会TLE啊QAQ C题原来要预处理乘法逆元才能过啊QAQ 我沙茶啊我QAQ[还是太弱 嗯A题就是道水题 B题就是字符串Hash+暴力搜 C题就是组合数+容斥原理
- 【BZOJ 5000 OI树】
Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 107 Solved: 64[Submit][Status][Discuss] Description ...
- 基于Windows Server 2008 R2的Failover Cluster
转载一下别人的文章吧,写的不错 基于Windows Server 2008 R2的Failover Cluster(故障转移群集)部署Sql Server 2008 AA(主主) 模式群集(第一部分) ...
- Gradle for Android(一)
Gradle是一种基于Groovy的动态DSL,而Groovy语言是一种基于jvm的动态语言.这里只分享实际开发中会用到的场景,您不需要去学习Groovy语言,知道Java的您是很容易阅读Groovy ...
- Android APK瘦身方法小结
众所周知,APP包体的大小,会影响推广的难度,用户不太喜欢下载太大的APP,同类型同等功能的APP中往往是包体小的更受用户的青睐,所以降低包体是一项非常必要的事情,也是最近公司的APP需要降低包体,所 ...
- AngularJS 作用域与数据绑定机制
AngularJS 简介 AngularJS 是由 Google 发起的一款开源的前端 MVC 脚本框架,既适合做普通 WEB 应用也可以做 SPA(单页面应用,所有的用户操作都在一个页面中完成).与 ...
- 除了IE浏览器,其他浏览器都联不上网怎么办~转载百度经验
百度师傅最快的到家服务,最优质的电脑清灰 百度经验:jingyan.baidu.com 有个网友遇到一个非常奇怪的上网问题,刚才始,发现QQ不能登录,后来接着发现火狐浏览器也打不开网页,刚开始,以为只 ...
- ping(NOIP模拟赛Round 4)第一次程序Rank 1!撒花庆祝!~\(≧▽≦)/~
题目: 恩,就是裸的字符串处理啦. 连标程都打的是暴力(随机数据太水啦!吐槽.) 本来O(n^2q)TLE好吧.. 然后我发明了一种神奇的算法,随机数据跑的很快!,当然最坏复杂度跟标程一样啦. 不过期 ...