3

我在尝试运行没有错误导出的 Eclipse 产品时遇到了以下异常

java.lang.NullPointerException
    at org.eclipse.e4.ui.internal.workbench.ModelServiceImpl.<init>

任何线索?

完整的堆栈跟踪:

!SESSION 2013-07-23 02:08:52.676 -----------------------------------------------
eclipse.buildId=unknown
java.version=1.7.0_21
java.vendor=Oracle Corporation
BootLoader constants: OS=linux, ARCH=x86_64, WS=gtk, NL=en_US
Command-line arguments:  -os linux -ws gtk -arch x86_64

!ENTRY org.eclipse.osgi 4 0 2013-07-23 02:08:54.202
!MESSAGE Application error
!STACK 1
java.lang.NullPointerException
    at org.eclipse.e4.ui.internal.workbench.ModelServiceImpl.<init>(ModelServiceImpl.java:124)
    at org.eclipse.e4.ui.internal.workbench.swt.E4Application.createDefaultContext(E4Application.java:471)
    at org.eclipse.e4.ui.internal.workbench.swt.E4Application.createE4Workbench(E4Application.java:199)
    at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:581)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:567)
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:150)
    at myapp.MyApp.start(MyApp.java:20)
    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:354)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:181)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:601)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:636)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:591)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1450)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1426)
4

3 回答 3

9

将我的 Eclipse 3.7 应用程序更新到 4.3 后,我遇到了同样的问题。解决方案是将我的产品文件中标签的内容替换为以下内容:

<configurations>
   <plugin id="org.eclipse.core.runtime" autoStart="true" startLevel="2" />
   <plugin id="org.eclipse.equinox.ds" autoStart="true" startLevel="3" />
   <plugin id="org.eclipse.equinox.event" autoStart="true" startLevel="3" />
</configurations>

另请参阅http://wiki.eclipse.org/Eclipse4/RCP/FAQ#Why_won.27t_my_application_start.3F

于 2013-08-26T14:52:09.033 回答
0

尝试删除调试配置名称中的空格。

我很不愿意在这里写这个,因为我知道这听起来很疯狂,而且我没有任何证据/解释。但这是我的故事。
我正在翻译我的 Eclipse Java 应用程序 (RCP) 并有 2 个调试启动配置。一个以荷兰语发布,1 个以英语发布。
突然之间,这些停止使用上面的堆栈跟踪。
我开始撤消更改,但无济于事。
互联网搜索将我带到这里,但接受的答案提出的更改对我的情况没有帮助。
然后我通过单击产品清单中的调试图标创建了一个新的启动配置。
那个有效。检查启动配置文件中的差异显示除了配置名称和位置之外没有差异。作为一个 C/C++ 人,我删除了 gui 中配置名称中的空格,然后它又开始工作了:-s
奇怪的是,两个配置都包含空格,并且通过删除其中一个中的空格,它们都开始工作了。因为我花了 4 个多小时来解决这个问题,所以我想我会分享这个。

于 2018-05-23T17:57:35.863 回答
-1

您可以编辑您的congif.ini

前:

osgi.bundles=org.eclipse.equinox.common@2:start,org.eclipse.update.configurator@3:start,org.eclipse.core.runtime@start

后:

osgi.bundles=org.eclipse.equinox.common@2:start,org.eclipse.update.configurator@3:start,org.eclipse.equinox.ds@2:start,org.eclipse.core.runtime@start

于 2016-09-08T05:05:15.633 回答