一、异常现象

在运行RCP程序时,出现

java.lang.RuntimeException: No application id has been found.
    at org.eclipse.equinox.internal.app.EclipseAppContainer.startDefaultApp(EclipseAppContainer.java:242)
    at org.eclipse.equinox.internal.app.MainApplicationLauncher.run(MainApplicationLauncher.java:29)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:134)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:104)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:388)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:243)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:653)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:590)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1499)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1472)

 

通出,在修改了程序中的某个插件(如添加一个扩展等)后,没有引入包含该扩展点的插件,就直接通过产品配置编辑器的界面运行程序,这时就会发生此异常。

 

二、异常原因

1.异常原因

      产品配置中所包含的插件不够,不足以启动RCP程序所致。

 

也就是说,有某些必需的插件没有引入。

 

2.例子

例如,插件A添加了一个扩展,对应的扩展点包含在插件X中,而插件X却没有被加到产品配置的插件列表中。(或者使用的插件X与它所依赖的插件不配套等)

这时就会出现上述异常。

 

三、异常解决

将程序必需的插件都添加进去即可。

 

1.通常情况

如果是通过插件配置产品,

1.1 打开产品配置,在Contens页面,点击“Add Required Plug-ins”,即可。

Eclipse插件开发_异常_01_java.lang.RuntimeException: No application id has been found._java

 

1.2 配置 Run Configuration

(1)配置Main

Eclipse插件开发_异常_01_java.lang.RuntimeException: No application id has been found._eclipse_02

 

(2) 配置Plug-ins

点击 Add Required Plug-ins

Eclipse插件开发_异常_01_java.lang.RuntimeException: No application id has been found._正常运行_03

 

 

点击Apply,Run,发现插件能正常运行。

 

2.特殊情况

若通过1中方法还是不行。

(1)则在配置Run Configuration的Plug-ins时,勾选 Select All。然后运行,发现又能正常运行了。

 

(2)然后再将Plug-ins配置成 Add Required Plug-ins ,再运行,发现能正常运行了。

 

 至于其中原因,暂时不知道。也希望读者能帮我解惑!

四、参考资料

1.参考:《Eclipse插件开发学习笔记》(2008年第一版),第627-628页