1 、 java.lang.OutOfMemoryError: PermGen space
JVM 经管两种类型的内存,堆和非堆。堆是给开辟人员用的上方说的就是,是在 JVM 启动时创建;非堆是留给 JVM 本身用的,用来存放类的信息的。它和堆不合,运行期内 GC 不会开释空间。若是 web app 用了多量的第三方 jar 或者应用有太多的 class 文件而正好 MaxPermSize 设置较小,超出了也会导致这块内存的占用过多造成溢出,或者 tomcat 热安排时侯不会清理前面加载的景象,只会将 context 更改为新安排的,非堆存的内容就会越来越多。
2 、 java.lang.OutOfMemoryError: Java heap space
第一种景象是个补充,首要存在题目就是呈如今这个景象中。其默认空间 ( 即 -Xms) 是物理内存的 1/64 ,最大空间 (-Xmx) 是物理内存的 1/4 。若是内存残剩不到 40 %, JVM 就会增大堆到 Xmx 设置的值,内存残剩跨越 70 %, JVM 就会减小堆到 Xms 设置的值。所以办事器的 Xmx 和 Xms 设置一般应当设置雷同避免每次 GC 后都要调剂虚拟机堆的大小。假设物理内存无穷大,那么 JVM 内存的最大值跟操纵体系有关,一般 32 位机是 1.5g 到 3g 之间,而 64 位的就不会有限制了。
重视:若是 Xms 跨越了 Xmx 值,或者堆最大值和非堆最大值的总和跨越了物理内存或者操纵体系的最大限制都邑引起办事器启动不起来。
垃圾收受接管 GC 的角色
JVM 调用 GC 的频度还是很高的,首要两种景象下进行垃圾收受接管:
当应用法度线程余暇;另一个是 java 内存堆不足时,会络续调用 GC ,若连气儿收受接管都解决不了内存堆不足的题目时,就会报 out of memory 错误。因为这个异常按照体系运行景象决意,所以无法预期它何时呈现。
按照 GC 的机制,法度的运行会引起体系运行景象的变更,增长 GC 的触发机会。
为了避免这些题目,法度的设计和编写就应避免垃圾对象的内存占用和 GC 的开销。显示调用 System.GC() 只能建议 JVM 须要在内存中对垃圾对象进行收受接管,但不是必须即速收受接管,
一个是并不克不及解决内存资料耗空的场合排场,别的也会增长 GC 的消费。
可以试一试再下载一个,如果不行就卸载一些不必要的东东,再试试,说不定就可以了,其实我的电脑还没有你好,却从来没有过,不妨卸载一些东西再试试。、
纯手打望采纳。
内存卡4gb,可以的啊??