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