2

数日前、Eclipse RCP アプリケーションで Guava の使用を開始することにしました。http://central.maven.org/maven2/com/google/guava/guava/14.0.1/から guava-14.0.1.jar をダウンロードしました。

eclipse.exe を開始した後、アプリケーションがクラッシュしました。.metadata/.log ファイルに次のエラーが含まれていました:

!ENTRY org.eclipse.osgi 4 0 2013-08-12 15:56:32.033
!MESSAGE Application error
!STACK 1
java.lang.NoClassDefFoundError: com/google/common/base/Optional
    at com.treeage.treeagepro.license.LicenseLevel.<clinit>(Unknown Source)
    at com.treeage.treeagepro.license.LicenseInfo.<init>(Unknown Source)
    at com.treeage.treeagepro.license.LicenseManager.<init>(Unknown Source)
    at com.treeage.treeagepro.license.LicenseManager.getManager(Unknown Source)
    at com.treeage.treeagepro.app.ApplicationWorkbenchAdvisor.initialize(Unknown Source)
    at org.eclipse.ui.application.WorkbenchAdvisor.internalBasicInitialize(WorkbenchAdvisor.java:188)
    at org.eclipse.ui.internal.Workbench$28.runWithException(Workbench.java:1541)
    at org.eclipse.ui.internal.StartupThreading$StartupRunnable.run(StartupThreading.java:31)
    at org.eclipse.swt.widgets.RunnableLock.run(RunnableLock.java:35)
    at org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:135)
    at org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:4144)
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3761)
    at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2609)
    at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2499)
    at org.eclipse.ui.internal.Workbench$7.run(Workbench.java:679)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:668)
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
    at com.treeage.treeagepro.app.Application.start(Unknown Source)
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:353)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:180)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:629)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:584)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1438)
Caused by: java.lang.ClassNotFoundException: com.google.common.base.Optional
    at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:501)
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:421)
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:412)
    at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.loadClass(DefaultClassLoader.java:107)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 31 more

アプリケーションが管理者として実行されている場合、エラーはありません。

アプリケーションは 64 ビットであるため、これは UAC 仮想化の問題ではありません。しかし、問題は何らかの形でアクセス許可に関連しているようです。


guava-14.0.1.jar は有効な OSGi バンドルのようです: https://code.google.com/p/guava-libraries/issues/detail?id=688 (少なくとも、MANIFEST.MF に必要なすべてのヘッダーが見つかりました)

助言がありますか?

4

3 に答える 3

1

C:\Users\<user_name>\.eclipseフォルダーを一掃することで問題を解決しました。この問題は、OSGi (Equinox) の一時ディレクトリに関係しているようです。

于 2013-09-04T14:29:02.430 に答える
0

RCP の製品構成で使用している機能にバンドルが含まれているかどうかを再確認してください。正しいシンボリック名を使用しているかどうか、および正しいバージョンが必要かどうかを再確認してください。ビルド時にグアバ jar がターゲット プラットフォームに適切にコピーされなかったため、私はあなたのような問題を抱えていました。

私の場合、Eclipse Xtext と他のコンポーネントが古いバージョンを使用しているため、バージョン 0.14.1 がコピーされていることを確認するために、feature.xml に次を追加する必要がありました。

<requires>
    <import plugin="com.google.guava" version="0.14.1"/>
    ....
</requires>
<plugin
     id="com.google.guava"
     download-size="0"
     install-size="0"
     version="0.0.0"
     unpack="false"/>
于 2013-08-12T22:14:10.577 に答える
0

あなたの最後のコメントに基づいて、これは Java や OSGi に関連したものではなく、おそらくファイルシステムのパーミッションの問題だと思います。

あなたはしたいかもしれません:

  • その特定のフォルダーとそのサブフォルダーとファイルをチェックして、不正なアクセス許可要件 (右クリック、プロパティ、セキュリティ タブ) を確認します。
  • フォルダー全体を削除して再作成し、別の結果を確認するために再試行してください。
于 2013-09-04T13:04:34.783 に答える