我正在开发一个eclipse插件。我已经使用一个动作声明了一个动作集,但是当动作被调用时,它没有按照它应该做的那样。
这是行动的类。
package instantmessengerplugin;
import java.io.IOException;
import org.eclipse.jface.action.Action;
import org.eclipse.jface.action.IAction;
import org.eclipse.jface.viewers.ISelection;
import org.eclipse.ui.IWorkbenchWindow;
import org.eclipse.ui.IWorkbenchWindowActionDelegate;
public class ActionClass implements IWorkbenchWindowActionDelegate {
@Override
public void dispose() {
// TODO Auto-generated method stub
}
@Override
public void init(IWorkbenchWindow window) {
//this.window = window;
}
@Override
public void run(IAction arg0) {
System.out.println("hello");
Connection.main(null);
}
@Override
public void selectionChanged(IAction arg0, ISelection arg1) {
// TODO Auto-generated method stub
}
}
所以我知道这个类工作正常,因为run方法中的print语句执行正常。
连接包含在我添加到类路径的jar中。它存在于项目的引用库中。我的目标是让动作启动jar文件。
我在Connection.main行上运行了调试器。
这是我进入这一行时的堆栈:
EventTable.sendEvent(Event) line: 87
ToolItem(Widget).sendEvent(Event) line: 1003
Display.runDeferredEvents() line: 3880
Display.readAndDispatch() line: 3473
Workbench.runEventLoop(Window$IExceptionHandler, Display) line: 2405
Workbench.runUI() line: 2369
Workbench.access$4(Workbench) line: 2221
Workbench$5.run() line: 500
Realm.runWithDefault(Realm, Runnable) line: 332
Workbench.createAndRunWorkbench(Display, WorkbenchAdvisor) line: 493
PlatformUI.createAndRunWorkbench(Display, WorkbenchAdvisor) line: 149
IDEApplication.start(IApplicationContext) line: 113
EclipseAppHandle.run(Object) line: 194
EclipseAppLauncher.runApplication(Object) line: 110
EclipseAppLauncher.start(Object) line: 79
EclipseStarter.run(Object) line: 368
EclipseStarter.run(String[], Runnable) line: 179
NativeMethodAccessorImpl.invoke0(Method, Object, Object[]) line: not available [native method]
NativeMethodAccessorImpl.invoke(Object, Object[]) line: not available
DelegatingMethodAccessorImpl.invoke(Object, Object[]) line: not available
Method.invoke(Object, Object...) line: not available
Main.invokeFramework(String[], URL[]) line: 559
Main.basicRun(String[]) line: 514
Main.run(String[]) line: 1311
Main.main(String[]) line: 1287
我不知道该怎么做。我相信如果我理解了这个堆栈,我就能解决它。
有人能看出问题所在吗?从日食行动中启动罐子有什么问题吗?
答案 0 :(得分:0)
也许Jar是用比eclipse当前使用的更新的jdk构建的。我过去也遇到过类似的问题。
答案 1 :(得分:0)
事件处理程序抛出异常并被其吃掉。此异常可能在错误日志中,因此查看该异常可能会为您提供更多提示。
问题可能是几件事,但很可能由于某种原因无法加载Connection类,并且抛出了ClassNotFoundException。