2015-10-23 37 views
6

Javaコンパイラに問題があります。簡単なプログラムをコンパイルするとJavaコンパイラが失敗する

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はこれをコンパイルに失敗するのはなぜ:私は取得していますコンパイルした後

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++; 
    } 
} 

:私はに私のコードを簡素化?

+2

1.8.0_60と同じ動作です。コンパイルをプログラムするかどうかにかかわらず、コンパイラは例外をスローしてはいけませんので、おそらくバグを報告するべきです。 – assylias

+2

* Javaがコンパイルに失敗する理由*:エラーメッセージには、理由:コンパイラにバグがあります。 –

+2

1.8.0_66にアップグレードしましたが、Javaコンパイラはまだクラッシュしています。私はバグを報告します。 – Yozer

答えて

4

これは明らかにコンパイラのバグです。あなたは、出力指示するとバグを報告しなければならないが、あなたはなぜを尋ねたので、私はJDK langtools repojavacのコードが含まれてい

:)ことを探求しようとするでしょう。 buildsをいくつか閲覧しましたが、スタックトレースと一致する行番号を持つバージョンを見つけることができませんでした(私は match a Java version to a build numberの方法はわかりません)ので、最新のビルド b132から出ています。

ご覧のとおり、根本的な問題は、com.sun.tools.javac.code.SymbolNullPointerExceptionSymbol.ClassSymbol.isSubClass()です。それが問題の原因です。スタックトレースでは、access()accessSymbol()となり、accessClass()となり、isSubClass()に達することがわかります。したがって、コンパイラは、サブクラスが失敗したときにsuper.valueにアクセスすることが許可されていることを確認しようとしていると推測できます。

NPEがどの回線で発生しているのかわからなくても、正確な問題を特定するのは難しいので、残念ながらここでは曖昧になります。このエラーはフィールドをインクリメント・アンド・セット(++または+=)すると発生し、super.valueと指定した場合にのみ、キャスト、オートボクシング、割り当て、または算術演算に関連するコードがいくつか見込まれます。ああ、isSubClass()の何も本当にそれに関係しているようです。

私の推測では、isSubClass()で自分に不利なものがあるように見えないことを考えると、Lower.accessClass()isSubClass()nullを渡しているということです。この方法でisSubClass()に渡された三つの値があります:フィールドcurrentClassは(cとして、これは「現在囲むクラス」である)、sym.owner(私はそのownerがあるかわからない、symは、私たちのvalue分野だと思いますが、おそらくそれが宣言されたクラス)、およびtypes(常にnull以外の値に設定されているように見えます)。したがって、currentClassまたはsym.ownerのいずれかであり、への参照があるため、NPEはLower.access()に先行しているため、nullではないようです。

だから、何らかの理由でLower.currentClassがヌルであることが原因である可能性があります。 currentClassはパッケージ非公開の非最終フィールドですので、現時点でnullになるかどうかを判断しようとはしませんが、可能性があります。もちろん、isSubClass()には他にもいくつかの犯人がいる可能性があるので、間違いかもしれません。

私はこれが参考になることを望みます。もっと学ぶと確かに更新されます。

関連する問題