开发者社区> 问答> 正文

java运行过程中OutOfMemoryError是什么原因?怎么解决

java.lang.OutOfMemoryError: getNewTla

        at java.util.HashMap.newValueIterator(HashMap.java:1027)

        at java.util.HashMap$Values.iterator(HashMap.java:1098)

        at java.util.Collections$SynchronizedCollection.iterator(Collections.java:1573)

        at net.sf.ehcache.store.DiskStore.expireElements(DiskStore.java:858)

        at net.sf.ehcache.store.DiskStore.expiryThreadMain(DiskStore.java:832)

        at net.sf.ehcache.store.DiskStore.access$700(DiskStore.java:59)

        at net.sf.ehcache.store.DiskStore$ExpiryThread.run(DiskStore.java:1008)

展开
收起
a123456678 2016-03-18 09:42:16 2481 0
1 条回答
写回答
取消 提交回答
  • 1.内存中加载的数据量过于庞大,如一次从数据库取出过多数据;

    2.集合类中有对对象的引用,使用完后未清空,使得JVM不能回收;

    3.代码中存在死循环或循环产生过多重复的对象实体;

    4.使用的第三方软件中的BUG;

    5.启动参数内存值设定的过小;

    2.Java代码导致错误的解决: 重点排查以下几点:

    1)检查代码中是否有死循环或递归调用。

    2)检查是否有大循环重复产生新对象实体。

    3)检查对数据库查询中,是否有一次获得全部数据的查询。一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用分页的方式查询。

    4 )检查List、MAP等集合对象是否有使用完后,未清除的问题。List、MAP等集合对象会始终存有对对象的引用,使得这些对象不能被GC回收。

    查询数据时,一次查询过多的数据,后来调整了该部分的代码,每次只取出指定量的数据,成功的解决该问题。

    出现OutOfMemoryError,发现session的资源一直没有被释放产生的,最好通过session的invalidate()方法将session的资源释放。

    程序中出现死循环。 4.tomcat部署、运行出现OutOfMemoryError,加大内存参数值,解决此问题。

    2019-07-17 19:05:55
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
Spring Cloud Alibaba - 重新定义 Java Cloud-Native 立即下载
The Reactive Cloud Native Arch 立即下载
JAVA开发手册1.5.0 立即下载