问题描述
当Project的代码量达到Idea编译的上限时,Idea将无法自动分配足够的内存给Project,这就直接导致出现了“系统资源不足”的编译中断异常。
错误如下图所示
之所以导致上面的编译中断异常出现,还需要来看看Idea的编译过程
Idea在编译时会动态的分配内存给Project,而windows也会给idea分配的内存,当windows分配给Idea的内存少于Project所需或者已经达到一定的临界点时,就会导致Idea编译工具编译中断,抛出内存溢出的错误。
解决方案一
解决这个问题的关键是我们需要理解下面这句话
windows给idea分配的内存或者Idea分配给Project的内存已经达到一定的临界点了,才导致了内存溢出了。
至此,我们知道了问题的根源所在,那么我们只要逆向思维“如果不让window有分配Idea内存,Idea分配给Project内存的机会,或者换一种编译的方式”,那我们这个错误不就是解决了么!
解决工具
使用ant编译
使用ant编译是不消耗操作系统给你idea分配的内存。ant编译的原理与idea是分开的。Ant编译直接消耗的系统内存(windows),所以不需要消耗idea的内存。就算Idea的内存分配的再小也是不会影响ant编译,所以不会报错。
解决步骤
基本上每一个Java Project中都会有一个名叫native.xml的ant编译解析文件,至于这个文件中的内容和用法我这里就不多作介绍了。
第一步:native配置
只要保证Native.xml文件中有如下代码就可以解决此问题了,至于你其它的代码互不影响,该怎么写还是怎么写。下面主要是3个方面的配置,一个是将src目录下面的文件编译输出到Classes目录下,第二个是转码,第三个是拷贝conf文件夹下面的配置文件。这三个配置都是可以单独使用和运行的,这里我们想要解决Idea的问题,就引出第四个配置“解决Idea编译报系统资源不足的错误”的配置,具体怎么配置代码如下图所示。
第二步:ant运行native文件
如果你还没有把native文件设置成ant编译文件,那也不用急,只需要在右边的Ant Build的对话框中找到那个小加号点击后就会出现
选择对话框,你只要找到你的native.xml文件的路径就好了。配置成功后你就会看到下图右边的菜单项了。
这时你直接双击“解决Idea编译报系统资源不足的错误”这个选项,Ant就去执行它的任务去了。编译成功后会出现如下提示信息窗口。至此,我要恭喜你,我们已经解决了Idea编译出现系统资源不足的错误。
第三步:去掉Idea编译配置
接下来找到上面的服务配置对话窗口,然后去掉Make和Build“test”artifact的选项,最后启动服务就好了。
Ps:我这里用的是Tomcat,如果你用别的应用服务器,此操作依旧。
相关源码
<!--解决Idea编译报系统资源不足的错误 -->
<target name="解决Idea编译报系统资源不足的错误" depends="compile,copyConf">
</target>
<!--编译Class,将Src目录下面的文件编译输出到Classes目录下-->
<target name="compile" description="compile the source ">
<javac srcdir="${src.dir}" destdir="${classes.dir}" encoding="GBK" optimize="off" fork="true" includes="**/*.java" memorymaximumsize="500M" classpathref="lib"/>
</target>
<!--转码-->
<target name="CH-native">
<delete>
<fileset dir="${classes.dir}/com" includes="**/*.properties"/>
</delete>
<native2ascii encoding="gb2312" src="${src.dir}/com" dest="${classes.dir}/com"
includes="**/*.properties" excludes="**/*.svn"/>
</target>
<!--拷贝conf文件夹下面的配置文件-->
<target name="copyConf" depends="CH-native">
<copy includeemptydirs="false" todir="${classes.dir}" overwrite="true">
<fileset dir="${conf.dir}" excludes="**/*.svn, **/*.java"/>
</copy>
</target>
解决方案二
方案二是我在方案一之后才发现的解决方案,其只需要简单的配置一下就好了。
如下图,打开设置面板,找到Java Compiler项,将最大内存大小修改成原来的两倍就好了。
解决方案三
方案三是方案二的扩展,与方案二不同的是编译类的方式不同(这里我们选择Eclipse编译方式),但是最大内存大小还是需要扩大,如下图