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

Posted

技术标签:

【中文标题】尝试运行 Eclipse 产品时出现异常【英文标题】:Exception while trying to run eclipse product 【发布时间】:2013-07-22 01:52:59 【问题描述】:

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

【问题讨论】:

你能粘贴完整的堆栈跟踪吗? @saurav 更新了完整的跟踪信息。谢谢! 这个链接应该对eclipse.org/forums/index.php/t/275845有帮助 @saurav 我看到了这个,但这真的有帮助吗?你自己见过这个问题吗?您是如何解决的? 【参考方案1】:

在将我的 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

【讨论】:

谢谢!如果可行,我会尝试并将其标记为答案! “产品文件”在哪里,它的确切名称是什么? 通常在你项目的根目录下。如果你没有这样的文件,你必须先创建一个产品(CTRL + N -> 产品配置)。【参考方案2】:

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

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

【讨论】:

【参考方案3】:

您可以编辑您的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 @开始

【讨论】:

以上是关于尝试运行 Eclipse 产品时出现异常的主要内容,如果未能解决你的问题,请参考以下文章

Eclipse 工作区? Eclipse 启动时出现问题

在 Eclipse Juno 中运行 Groovy 时出现异常 java.lang.IncompatibleClassChangeError

尝试从 maven 运行 java 程序时出现异常

运行 Eclipse 导出的 jar 时出现“找不到主类”错误

尝试在 iOS 中连接 ManagedObjectContext 时出现运行时异常

将 Tomcat 添加为服务器运行时环境时出现 Eclipse 错误