Java编译器在编译简单程序时失败

Java编译器在编译简单程序时失败,java,compilation,Java,Compilation,我对Java编译器有问题。我将代码简化为: package a; public class Base { // compiles if this is made public or an int protected Integer value = 0; } --- package b; // must be in a separate package import a.Base; public class Sub extends Base { public void inc

我对Java编译器有问题。我将代码简化为:

package a;

public class Base {
  // compiles if this is made public or an int
  protected Integer value = 0;
}

---

package b; // must be in a separate package

import a.Base;

public class Sub extends Base {
  public void increment() {
    System.out.println(super.value);
    value++;
    super.value = 1;
    super.value = super.value + 1;
    // this line crashes the compiler; the others all work
    super.value++;
  }
}
编译后,我得到:

Information:java: An exception has occurred in the compiler (1.8.0_51). 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.
Information:java: java.lang.NullPointerException
Information:java:   at com.sun.tools.javac.code.Symbol$ClassSymbol.isSubClass(Symbol.java:1020)
Information:java:   at com.sun.tools.javac.comp.Lower.accessClass(Lower.java:1108)
Information:java:   at com.sun.tools.javac.comp.Lower.accessSymbol(Lower.java:983)
Information:java:   at com.sun.tools.javac.comp.Lower.access(Lower.java:1220)
Information:java:   at com.sun.tools.javac.comp.Lower.visitSelect(Lower.java:3855)
Information:java:   at com.sun.tools.javac.tree.JCTree$JCFieldAccess.accept(JCTree.java:1897)
Information:java:   at com.sun.tools.javac.tree.TreeTranslator.translate(TreeTranslator.java:58)
Information:java:   at com.sun.tools.javac.comp.Lower.translate(Lower.java:2371)
Information:java:   at com.sun.tools.javac.comp.Lower.translate(Lower.java:2382)
Information:java:   at com.sun.tools.javac.comp.Lower.visitVarDef(Lower.java:3547)
Information:java:   at com.sun.tools.javac.tree.JCTree$JCVariableDecl.accept(JCTree.java:852)
Information:java:   at com.sun.tools.javac.tree.TreeTranslator.translateVarDefs(TreeTranslator.java:78)
Information:java:   at com.sun.tools.javac.comp.Lower.visitLetExpr(Lower.java:3859)
Information:java:   at com.sun.tools.javac.tree.JCTree$LetExpr.accept(JCTree.java:2426)
Information:java:   at com.sun.tools.javac.comp.Lower.visitLetExpr(Lower.java:3860)
Information:java:   at com.sun.tools.javac.comp.Lower.visitUnary(Lower.java:3319)
Information:java:   at com.sun.tools.javac.tree.JCTree$JCUnary.accept(JCTree.java:1746)
Information:java:   at com.sun.tools.javac.tree.TreeTranslator.visitExec(TreeTranslator.java:245)
Information:java:   at com.sun.tools.javac.tree.JCTree$JCExpressionStatement.accept(JCTree.java:1296)
Information:java:   at com.sun.tools.javac.tree.TreeTranslator.translate(TreeTranslator.java:70)
Information:java:   at com.sun.tools.javac.tree.TreeTranslator.visitBlock(TreeTranslator.java:162)
Information:java:   at com.sun.tools.javac.comp.Lower.visitBlock(Lower.java:3561)
Information:java:   at com.sun.tools.javac.tree.JCTree$JCBlock.accept(JCTree.java:909)
Information:java:   at com.sun.tools.javac.tree.TreeTranslator.visitMethodDef(TreeTranslator.java:145)
Information:java:   at com.sun.tools.javac.comp.Lower.visitMethodDefInternal(Lower.java:2828)
Information:java:   at com.sun.tools.javac.comp.Lower.visitMethodDef(Lower.java:2737)
Information:java:   at com.sun.tools.javac.tree.JCTree$JCMethodDecl.accept(JCTree.java:778)
Information:java:   at com.sun.tools.javac.comp.Lower.visitClassDef(Lower.java:2508)
Information:java:   at com.sun.tools.javac.tree.JCTree$JCClassDecl.accept(JCTree.java:693)
Information:java:   at com.sun.tools.javac.comp.Lower.translate(Lower.java:2390)
Information:java:   at com.sun.tools.javac.comp.Lower.translateTopLevelClass(Lower.java:3932)
Information:java:   at com.sun.tools.javac.main.JavaCompiler.desugar(JavaCompiler.java:1512)
Information:java:   at com.sun.tools.javac.main.JavaCompiler.desugar(JavaCompiler.java:1356)
Information:java:   at com.sun.tools.javac.main.JavaCompiler.compile2(JavaCompiler.java:901)
Information:java:   at com.sun.tools.javac.main.JavaCompiler.compile(JavaCompiler.java:860)
Information:java:   at com.sun.tools.javac.main.Main.compile(Main.java:523)
Information:java:   at com.sun.tools.javac.api.JavacTaskImpl.doCall(JavacTaskImpl.java:129)
Information:java:   at com.sun.tools.javac.api.JavacTaskImpl.call(JavacTaskImpl.java:138)
Information:java:   at org.jetbrains.jps.javac.JavacMain.compile(JavacMain.java:168)
Information:java:   at org.jetbrains.jps.incremental.java.JavaBuilder.compileJava(JavaBuilder.java:382)
Information:java:   at org.jetbrains.jps.incremental.java.JavaBuilder.compile(JavaBuilder.java:296)
Information:java:   at org.jetbrains.jps.incremental.java.JavaBuilder.doBuild(JavaBuilder.java:204)
Information:java:   at org.jetbrains.jps.incremental.java.JavaBuilder.build(JavaBuilder.java:176)
Information:java:   at org.jetbrains.jps.incremental.IncProjectBuilder.runModuleLevelBuilders(IncProjectBuilder.java:1202)
Information:java:   at org.jetbrains.jps.incremental.IncProjectBuilder.runBuildersForChunk(IncProjectBuilder.java:877)
Information:java:   at org.jetbrains.jps.incremental.IncProjectBuilder.buildTargetsChunk(IncProjectBuilder.java:948)
Information:java:   at org.jetbrains.jps.incremental.IncProjectBuilder.buildChunkIfAffected(IncProjectBuilder.java:840)
Information:java:   at org.jetbrains.jps.incremental.IncProjectBuilder.buildChunks(IncProjectBuilder.java:665)
Information:java:   at org.jetbrains.jps.incremental.IncProjectBuilder.runBuild(IncProjectBuilder.java:372)
Information:java:   at org.jetbrains.jps.incremental.IncProjectBuilder.build(IncProjectBuilder.java:193)
Information:java:   at org.jetbrains.jps.cmdline.BuildRunner.runBuild(BuildRunner.java:137)
Information:java:   at org.jetbrains.jps.cmdline.BuildSession.runBuild(BuildSession.java:293)
Information:java:   at org.jetbrains.jps.cmdline.BuildSession.run(BuildSession.java:124)
Information:java:   at org.jetbrains.jps.cmdline.BuildMain$MyMessageHandler$1.run(BuildMain.java:242)
Information:java:   at org.jetbrains.jps.service.impl.SharedThreadPoolImpl$1.run(SharedThreadPoolImpl.java:41)
Information:java:   at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
Information:java:   at java.util.concurrent.FutureTask.run(FutureTask.java:266)
Information:java:   at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
Information:java:   at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
Information:java:   at java.lang.Thread.run(Thread.java:745)
Information:java: Errors occurred while compiling module 'testAGH'
Information:2015-10-23 14:23 - Compilation completed with 1 error and 0 warnings in 671ms
Error:java: Compilation failed: internal java compiler error

为什么Java无法编译这个?

这显然是一个编译器错误。您应该按照输出的指示提交一个bug,但既然您问我为什么要尝试探究它:)

包含
javac
的代码。我浏览了几个不同的版本,但找不到与堆栈跟踪相匹配的行号版本(我不知道如何),所以我要退出最新的版本

如您所见,基本问题是中的
NullPointerException
。这就是问题的根源。在堆栈跟踪中往上看,我们可以看到
access()
调用
accessSymbol()
然后是
accessClass()
,然后才到达
isSubClass()
。因此,我们可以推断编译器正在尝试验证子类在失败时是否允许访问
super.value

如果不知道NPE发生在哪一条线上,就很难精确定位问题,所以不幸的是,这里的情况变得模糊了。由于此故障仅在尝试递增和设置(
++
+=
)字段时发生,并且仅当我们将其称为
super.value
时,我们希望看到一些与强制转换、自动装箱、赋值或算术相关的代码。唉,
isSubClass()
中似乎没有任何内容与此相关

我的猜测是,考虑到
isSubClass()
中似乎没有任何牵连,那就是将
null
传递到
isSubClass()
。在这个方法中,有三个值传递给
isSubClass()
:字段(作为
c
,这是“当前封闭的类”),
sym.owner
(我认为
sym
是我们的
字段,我不知道它的
所有者是什么,但可能是它声明的类),以及
类型
,它看起来总是被设置为非空值。所以要么是
currentClass
要么是
sym.owner
,而且前面会出现对
sym.owner
的引用,所以它似乎也是非空的

因此,我要冒昧地指出,罪魁祸首是
Lower。出于某种原因,currentClass
为空。由于
currentClass
是一个包私有的非最终字段,我不想费心去确定它此时是否可以
null
,但它似乎是可能的。当然,
isSubClass()
中还有其他几个可能的罪魁祸首,所以我很可能是错的


没有定论,但我希望这是有益的!如果我了解更多信息,我肯定会更新。

1.8.0_60的行为相同。无论您的程序是否编译,编译器都不应该抛出异常,因此您可能应该提交一个错误。为什么java无法编译:错误消息显示原因:编译器中存在错误。我升级到1.8.0_66,java编译器仍在崩溃。我将提交一个bug。我在Java jdk1.7.0_79中运行您的代码时没有任何问题