尝试运行eclipse产品时出现异常

时间:2013-07-23 06:13:04

标签: eclipse eclipse-plugin eclipse-rcp

我在尝试运行导出没有错误的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)

3 个答案:

答案 0 :(得分:7)

将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

答案 1 :(得分:0)

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

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

答案 2 :(得分:-1)

您可以修改congif.ini

之前:

  

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

后:

  

osgi.bundles=org.eclipse.equinox.common@2:启动,org.eclipse.update.configurator @ 3:启动,org.eclipse.equinox.ds @ 2:开始,org.eclipse.core.runtime @启动