AspectJ + Java 8 + ctrl使用中のエラー変数をクリック

user3822458

EclipseをLunaにアップグレードした後、クラス内の変数をCtrlキーを押しながらクリックしようとすると(Open Declarationを呼び出して)、何も起こりません。

Eclipseエラーログには、次のようなエラーが表示されます。

java.lang.ClassFormatError: Invalid length 65533 in LocalVariableTable in class file SomeClass
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:760)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:455)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:367)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at org.springframework.ide.eclipse.core.java.ClassUtils.loadClass(ClassUtils.java:156)
    at org.springframework.ide.eclipse.core.java.ClassUtils.loadClass(ClassUtils.java:147)
    at org.springframework.ide.eclipse.beans.core.autowire.internal.provider.AutowireDependencyProvider.getBeansForType(AutowireDependencyProvider.java:360)
    at org.springframework.ide.eclipse.beans.core.autowire.internal.provider.AutowireDependencyProvider.getBeansForType(AutowireDependencyProvider.java:346)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector$1.doWithActiveProjectClassLoader(AutowireHyperlinkDetector.java:139)
    at org.springframework.ide.eclipse.core.java.JdtUtils$DefaultProjectClassLoaderSupport.executeCallback(JdtUtils.java:977)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinksHelper(AutowireHyperlinkDetector.java:136)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinksHelper(AutowireHyperlinkDetector.java:117)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinksHelper(AutowireHyperlinkDetector.java:94)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinks(AutowireHyperlinkDetector.java:60)
    at org.eclipse.jdt.internal.ui.javaeditor.JavaElementHyperlinkDetector.detectHyperlinks(JavaElementHyperlinkDetector.java:114)
    at org.eclipse.ui.texteditor.HyperlinkDetectorRegistry$HyperlinkDetectorDelegate.detectHyperlinks(HyperlinkDetectorRegistry.java:80)
    at org.eclipse.jface.text.hyperlink.HyperlinkManager.findHyperlinks(HyperlinkManager.java:289)
    at org.eclipse.jface.text.hyperlink.HyperlinkManager.findHyperlinks(HyperlinkManager.java:261)
    at org.eclipse.jface.text.hyperlink.HyperlinkManager.mouseMove(HyperlinkManager.java:469)
    at org.eclipse.swt.widgets.TypedListener.handleEvent(TypedListener.java:212)
    at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
    at org.eclipse.swt.widgets.Display.sendEvent(Display.java:4353)
    at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1061)
    at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4172)
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3761)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$9.run(PartRenderingEngine.java:1151)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:1032)
    at org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:148)
    at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:636)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:579)
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:150)
    at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:135)
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:134)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:104)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:382)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:236)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:648)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:603)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1465)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1438)

そして

java.lang.NullPointerException
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinksHelper(AutowireHyperlinkDetector.java:148)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinksHelper(AutowireHyperlinkDetector.java:117)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinksHelper(AutowireHyperlinkDetector.java:94)
    at org.springframework.ide.eclipse.quickfix.hyperlinks.AutowireHyperlinkDetector.addHyperlinks(AutowireHyperlinkDetector.java:60)
    at org.eclipse.jdt.internal.ui.javaeditor.JavaElementHyperlinkDetector.detectHyperlinks(JavaElementHyperlinkDetector.java:114)
    at org.eclipse.ui.texteditor.HyperlinkDetectorRegistry$HyperlinkDetectorDelegate.detectHyperlinks(HyperlinkDetectorRegistry.java:80)
    at org.eclipse.jface.text.hyperlink.HyperlinkManager.findHyperlinks(HyperlinkManager.java:289)
    at org.eclipse.jface.text.hyperlink.HyperlinkManager.findHyperlinks(HyperlinkManager.java:261)
    at org.eclipse.jface.text.hyperlink.HyperlinkManager.mouseMove(HyperlinkManager.java:469)
    at org.eclipse.swt.widgets.TypedListener.handleEvent(TypedListener.java:212)
    at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
    at org.eclipse.swt.widgets.Display.sendEvent(Display.java:4353)
    at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1061)
    at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4172)
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3761)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$9.run(PartRenderingEngine.java:1151)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:1032)
    at org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:148)
    at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:636)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:579)
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:150)
    at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:135)
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:134)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:104)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:382)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:236)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:648)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:603)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1465)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1438)

EclipseからSpringProjectの性質を削除すると、問題が修正されます。AspectJ機能フォームプロジェクトを削除すると、問題も修正されます。ラムダ式を含むすべてのコードを削除すると、問題も修正されます。

誰かがこれを手伝ってくれる?

アンディクレメント

この問題はhttps://bugs.eclipse.org/bugs/show_bug.cgi?id=435446のAspectJ1.8.1で修正されているため、古いバージョンのAspectJを使用しているようですこの問題は、invokedynamic命令とtry..catchブロックを含むコードに織り込まれたことが原因でした。開発アップデートサイトからアップデートしてみましたか?

http://download.eclipse.org/tools/ajdt/44/dev/update

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

分類Dev

aspectj-maven-pluginを使用したJava 8用のSpring + AspectJウィービング

分類Dev

Java8用のMaven + AspectJウィービング

分類Dev

AspectJ Java 13サポート?

分類Dev

AspectJコンパイルの問題、java8ラムダ式、switchステートメント

分類Dev

Java 10用のaspectj-maven-plugin compilanceLevel

分類Dev

AspectJでJavaのエラーを適切に処理する

分類Dev

AOP-エラー:org.aspectj.runtime.internal.AroundClosureのjava.lang.StackOverflowError

分類Dev

IntelliJ IDEA + AspectJの

分類Dev

AspectJでのNoSuchMethodError

分類Dev

Gradle + AspectJ引数「aspectj 'を'(?、java.lang.String、?、?) 'に適用できません」のメソッドaspectj()が見つかりませんでした

分類Dev

Javaは内部クラスの非final変数でエラーを停止しました(Java 8)

分類Dev

AspectJを使用してJavaクラスの静的プロパティをインターセプトする方法は?

分類Dev

Java 8ストリームマップコレクターエラー-ロールを変数に解決できません

分類Dev

JavaがAspectJを介して関数呼び出しパラメーターにアクセスする

分類Dev

Java 7ではなくJava 8でジェネリックを使用したタイプエラー

分類Dev

Javaの8内のNULLと空のチェックとフラットなマップを使用して複数のリストをマージするには?

分類Dev

春のaspectjの意味

分類Dev

AspectJ:アスペクトライブラリをJavaプロジェクトに組み込む方法

分類Dev

マップリデュース手法を使用して、Java8の複数のクラスフィールドの概要を取得する

分類Dev

Java 8を使用したクラスの変換

分類Dev

Java 8 Streamを使用したDataProviderクエリのIndexOutOfBoundsException

分類Dev

Java8ジェネリック+ラムダ式を使用する場合の例外コンパイル時エラー

分類Dev

Java8ジェネリック+ラムダ式を使用する場合の例外コンパイル時エラー

分類Dev

モッククラスでの引数マッチングにJava8ラムダを使用する

分類Dev

Javaの8:DateTimeParseException

分類Dev

Aspectjを使用してJavaクラスからスローされた例外をキャッチして抑制する方法

分類Dev

HibernateとAspectJのJavaプロジェクトでSBTを使用することは可能ですか?

分類Dev

aspectjはjava.lang.Stringにメソッドを追加できますか

分類Dev

クラスが別のクラスローダーによってロードされるため、AspectJ autoproxyがGigaSpaces 8およびSpring 3で失敗する

Related 関連記事

  1. 1

    aspectj-maven-pluginを使用したJava 8用のSpring + AspectJウィービング

  2. 2

    Java8用のMaven + AspectJウィービング

  3. 3

    AspectJ Java 13サポート?

  4. 4

    AspectJコンパイルの問題、java8ラムダ式、switchステートメント

  5. 5

    Java 10用のaspectj-maven-plugin compilanceLevel

  6. 6

    AspectJでJavaのエラーを適切に処理する

  7. 7

    AOP-エラー:org.aspectj.runtime.internal.AroundClosureのjava.lang.StackOverflowError

  8. 8

    IntelliJ IDEA + AspectJの

  9. 9

    AspectJでのNoSuchMethodError

  10. 10

    Gradle + AspectJ引数「aspectj 'を'(?、java.lang.String、?、?) 'に適用できません」のメソッドaspectj()が見つかりませんでした

  11. 11

    Javaは内部クラスの非final変数でエラーを停止しました(Java 8)

  12. 12

    AspectJを使用してJavaクラスの静的プロパティをインターセプトする方法は?

  13. 13

    Java 8ストリームマップコレクターエラー-ロールを変数に解決できません

  14. 14

    JavaがAspectJを介して関数呼び出しパラメーターにアクセスする

  15. 15

    Java 7ではなくJava 8でジェネリックを使用したタイプエラー

  16. 16

    Javaの8内のNULLと空のチェックとフラットなマップを使用して複数のリストをマージするには?

  17. 17

    春のaspectjの意味

  18. 18

    AspectJ:アスペクトライブラリをJavaプロジェクトに組み込む方法

  19. 19

    マップリデュース手法を使用して、Java8の複数のクラスフィールドの概要を取得する

  20. 20

    Java 8を使用したクラスの変換

  21. 21

    Java 8 Streamを使用したDataProviderクエリのIndexOutOfBoundsException

  22. 22

    Java8ジェネリック+ラムダ式を使用する場合の例外コンパイル時エラー

  23. 23

    Java8ジェネリック+ラムダ式を使用する場合の例外コンパイル時エラー

  24. 24

    モッククラスでの引数マッチングにJava8ラムダを使用する

  25. 25

    Javaの8:DateTimeParseException

  26. 26

    Aspectjを使用してJavaクラスからスローされた例外をキャッチして抑制する方法

  27. 27

    HibernateとAspectJのJavaプロジェクトでSBTを使用することは可能ですか?

  28. 28

    aspectjはjava.lang.Stringにメソッドを追加できますか

  29. 29

    クラスが別のクラスローダーによってロードされるため、AspectJ autoproxyがGigaSpaces 8およびSpring 3で失敗する

ホットタグ

アーカイブ