2012-10-01 65 views
1

我只收到以下错误的Java代码运行mvn clean时:ArrayIndexOutOfBoundsException异常在编译时使用Maven

An exception has occurred in the compiler (1.6.0_34). Please file a bug at the 
Java Developer Connection (http://java.sun.com/webapps/bugreport) after 
checking the Bug Parade for duplicates. Include your program and the following 
diagnostic in your report. Thank you. 
java.lang.ArrayIndexOutOfBoundsException: 117920 
at com.sun.tools.javac.zip.ZipFileIndex.get4ByteLittleEndian(ZipFileIndex.java:644) 
at com.sun.tools.javac.zip.ZipFileIndex.access$500(ZipFileIndex.java:29) 
at com.sun.tools.javac.zip.ZipFileIndex$ZipDirectory.readEntry(ZipFileIndex.java:740) 
at com.sun.tools.javac.zip.ZipFileIndex$ZipDirectory.buildIndex(ZipFileIndex.java:720) 
at com.sun.tools.javac.zip.ZipFileIndex$ZipDirectory.access$000(ZipFileIndex.java:652) 
at com.sun.tools.javac.zip.ZipFileIndex.checkIndex(ZipFileIndex.java:261) 
at com.sun.tools.javac.zip.ZipFileIndex.<init>(ZipFileIndex.java:209) 
at com.sun.tools.javac.zip.ZipFileIndex.getZipFileIndex(ZipFileIndex.java:115) 
at com.sun.tools.javac.util.DefaultFileManager.openArchive(DefaultFileManager.java:621) 
at com.sun.tools.javac.util.DefaultFileManager.listDirectory(DefaultFileManager.java:309) 
at com.sun.tools.javac.util.DefaultFileManager.list(DefaultFileManager.java:890) 
at com.sun.tools.javac.jvm.ClassReader.fillIn(ClassReader.java:2130) 
at com.sun.tools.javac.jvm.ClassReader.complete(ClassReader.java:1781) 
at com.sun.tools.javac.code.Symbol.complete(Symbol.java:384) 
at com.sun.tools.javac.comp.Enter.visitTopLevel(Enter.java:274) 
at com.sun.tools.javac.tree.JCTree$JCCompilationUnit.accept(JCTree.java:446) 
at com.sun.tools.javac.comp.Enter.classEnter(Enter.java:238) 
at com.sun.tools.javac.comp.Enter.classEnter(Enter.java:252) 
at com.sun.tools.javac.comp.Enter.complete(Enter.java:457) 
at com.sun.tools.javac.comp.Enter.main(Enter.java:442) 
at com.sun.tools.javac.main.JavaCompiler.enterTrees(JavaCompiler.java:822) 
at com.sun.tools.javac.main.JavaCompiler.compile(JavaCompiler.java:727) 
at com.sun.tools.javac.main.Main.compile(Main.java:353) 
at com.sun.tools.javac.main.Main.compile(Main.java:279) 
at com.sun.tools.javac.main.Main.compile(Main.java:270) 
at com.sun.tools.javac.Main.compile(Main.java:87) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
at java.lang.reflect.Method.invoke(Method.java:597) 
at org.codehaus.plexus.compiler.javac.JavacCompiler.compileInProcess0(JavacCompiler.java:551) 
at org.codehaus.plexus.compiler.javac.JavacCompiler.compileInProcess(JavacCompiler.java:526) 
at org.codehaus.plexus.compiler.javac.JavacCompiler.compile(JavacCompiler.java:167) 
at org.apache.maven.plugin.AbstractCompilerMojo.execute(AbstractCompilerMojo.java:678) 
at org.apache.maven.plugin.CompilerMojo.execute(CompilerMojo.java:128) 
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:101) 
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:209) 
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153) 
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145) 
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84) 
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59) 
at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183) 
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161) 
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:320) 
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:156) 
at org.apache.maven.cli.MavenCli.execute(MavenCli.java:537) 
at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:196) 
at org.apache.maven.cli.MavenCli.main(MavenCli.java:141) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
at java.lang.reflect.Method.invoke(Method.java:597) 
at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:290) 
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:230) 
at  org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409) 
    at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352) 

,我现在用的就是如下环境:

  • Eclipse的伽利略
  • 的Java 1.6.0_34(32位64位机器)
  • JBoss Seam 2.2
  • JBoss AS 5.1

可能是什么问题?

+0

您是否阅读过该消息? _“请在检查Bug Parade上的重复项后,在Java开发人员连接(http://java.sun.com/webapps/bugreport)上提交一个错误。在您的报告中包含您的程序和以下诊断信息,谢谢。”_查看bugreport网站,看看是否有其他人报告过这一点。 –

+0

似乎它与合并的Jar文件有关,但很难说不知道你的项目在做什么。 http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=6232676 – noahlz

+0

我不知道如何重现这个错误,所以我没有提交报告到bugreport的oracle页面。我仍在研究如何以及为何抛出异常! – rodrigocprates

回答

1

我不明白这个问题,但我找到了一个解决方案:我清理了我的.m2目录并重新安装了jdk。

当然,这是一种我们永远无法重现的环境问题。

0

我也遇到过这个问题。我通过逐个减少pom依赖来解决这个问题。

最后我发现son-lib是问题的主要原因。所以我删除了这种依赖关系,一切正常。

+0

你能解释一下_why_删除这行有帮助吗?避免这个问题与修复它不同。 – CodingNinja

+0

对不起,我不知道为什么工作。对我来说有点困难,如果有一天你解决了问题,请告诉我。谢谢 – jayzc

相关问题