Java内存溢出的解决方案都有哪些
1个回答
展开全部
内存溢出可能是以下原因:
内存中加载的数据量过于庞大,如一次从数据库取出过多数据;
调用接口超时且超时等待时间设置过长;
集合类中有对对象的引用,使用完后未清空,使得JVM不能回收;
代码中存在死循环或循环产生过多重复的对象实体;
启动参数内存值设定的过小;
那么针对的结局方案:
优化数据库查询语句,如改成分页查询;
调用接口超时时间设置短一些,打印错误日志,修正超时的接口;
集合类使用完后设置成null,例:在执行完list之后写上list=null;
使用debug逐步查找死循环的代码
将jvm内存的值增大:-Xms1024m -Xmx1024m -XX:MaxNewSize=1024m -XX:MaxPermSize=1024m (设置的值依据服务器内存的大小来设定)
纯手打,望采纳。
内存中加载的数据量过于庞大,如一次从数据库取出过多数据;
调用接口超时且超时等待时间设置过长;
集合类中有对对象的引用,使用完后未清空,使得JVM不能回收;
代码中存在死循环或循环产生过多重复的对象实体;
启动参数内存值设定的过小;
那么针对的结局方案:
优化数据库查询语句,如改成分页查询;
调用接口超时时间设置短一些,打印错误日志,修正超时的接口;
集合类使用完后设置成null,例:在执行完list之后写上list=null;
使用debug逐步查找死循环的代码
将jvm内存的值增大:-Xms1024m -Xmx1024m -XX:MaxNewSize=1024m -XX:MaxPermSize=1024m (设置的值依据服务器内存的大小来设定)
纯手打,望采纳。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询