再现OutOfMemoryError:Java heap space

最近在做一个项目,使用架构是struts2.0+ejb3.0(struts2.0刚刚学习不久),本地服务器使用的是JBOSS4.0.5GA,
数据库是ORACLE10G,现正处于开发阶段,可是一个恼人的问题始终没办法解决----OutOfMemoryError:Java heap space. 使用Eclipse启动jboss后,运行几次就会出现内存溢出问题,我的机器是2GB内存,应该够用吧!
调整虚拟机参数也不行.
我怀疑是我的struts2的使用上有问题,可是找不出原因是什么,开始的时候我以为是JBOSS的问题,联系了JBOSS的余先生,那边的技术给我回复的mail是可能"返回的list没有释放".我迷糊了,我的view是用的freemarker,从action中取出的数据到ftl里面显示,这让我怎么释放呢?难道struts2本身没有清除valuestack的东东么?ActionContextCleanUp 难道不能解决这个问题么?
我的web.xml配置是:

<filter>
<filter-name>struts-cleanup</filter-name>
<filter-class>org.apache.struts2.dispatcher.ActionContextCleanUp</filter-class>
</filter>
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
</filter>
<filter-mapping>
<filter-name>struts-cleanup</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

Eclipse控制台输出的异常信息是:

16:30:39,687 ERROR [[default]] Servlet.service() for servlet default threw exception
java.lang.OutOfMemoryError: Java heap space
at java.lang.String.toCharArray(String.java:2726)
at freemarker.core.TextBlock.<init>(TextBlock.java:77)
at freemarker.core.FMParser.PCData(FMParser.java:2466)
at freemarker.core.FMParser.Content(FMParser.java:2528)
at freemarker.core.FMParser.OptionalBlock(FMParser.java:2742)
at freemarker.core.FMParser.Root(FMParser.java:2914)
at freemarker.template.Template.<init>(Template.java:149)
at freemarker.cache.TemplateCache.loadTemplate(TemplateCache.java:376)
at freemarker.cache.TemplateCache.getTemplate(TemplateCache.java:347)
at freemarker.cache.TemplateCache.getTemplate(TemplateCache.java:229)
at freemarker.template.Configuration.getTemplate(Configuration.java:487)
at freemarker.core.Environment.getTemplateForInclusion(Environment.java:1357)
at freemarker.core.Include.accept(Include.java:143)
at freemarker.core.Environment.visit(Environment.java:196)
at freemarker.core.MixedContent.accept(MixedContent.java:92)
at freemarker.core.Environment.visit(Environment.java:196)
at freemarker.core.Environment.process(Environment.java:176)
at freemarker.template.Template.process(Template.java:232)
at org.apache.struts2.views.freemarker.FreemarkerResult.doExecute(FreemarkerResult.java:168)
at org.apache.struts2.dispatcher.StrutsResultSupport.execute(StrutsResultSupport.java:178)
at com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:343)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
at com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:213)
at com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:218)
at com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:455)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:216)
at com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:150)
at org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:48)
at com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
at com.opensymphony.xwork2.DefaultActionInvocation$2.doProfiling(DefaultActionInvocation.java:219)

大家谁有没有好的建议和方法,谢谢了!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java heap space是一种常见的OutOfMemoryError错误,它表示Java堆内存不足。当Java应用程序需要分配更多的内存给对象,但是堆内存已经被完全使用时,就会抛出这个错误。 解决Java heap space错误的方法有以下几种: 1. 增加堆内存大小:可以通过在启动应用程序时使用-Xmx参数来增加堆内存的大小。例如,使用命令`java -Xmx2g MyApp`将堆内存大小设置为2GB。 2. 优化代码和内存使用:检查代码中是否存在内存泄漏或者不必要的对象引用。确保及时释放不再使用的对象,避免创建过多的临时对象。 3. 使用垃圾回收器:Java提供了不同的垃圾回收器,可以根据应用程序的需求选择合适的垃圾回收器。例如,使用G1垃圾回收器可以更好地处理大内存和多核处理器的情况。 4. 分析内存使用情况:使用工具如VisualVM或JConsole来监视和分析应用程序的内存使用情况,找出内存使用过多的地方,并进行优化。 5. 减少对象的创建和销毁:避免频繁地创建和销毁对象,可以使用对象池或缓存来重复使用对象,减少内存的使用。 6. 使用更高效的数据结构和算法:选择合适的数据结构和算法可以减少内存的使用。例如,使用HashMap代替ArrayList可以减少内存的占用。 范例:<<引用:java.lang.OutOfMemoryError: Java heap space。主要有3种比较常见的OutOfMemory Error: Java.lang.OutOfMemoryError: Java heap space java.lang.OutOfMemoryError: PermGen space java.lang.OutOfMemoryError: GC overhead limit exceeded 。 引用:java.lang.OutOfMemoryError: Java heap space。3. java.lang.OutOfMemoryError: GC overhead limit exceeded 。 请回答我或者给我介绍或演示一下:OutOfMemoryErrorJava heap space? 当Java应用程序需要分配更多的内存给对象,但是堆内存已经被完全使用时,就会抛出Java heap space错误。解决这个错误的方法包括增加堆内存大小、优化代码和内存使用、使用垃圾回收器、分析内存使用情况、减少对象的创建和销毁以及使用更高效的数据结构和算法。具体的方法可以根据应用程序的需求和情况来选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值