从Singleton触发GWT SimpleEventBus事件时出现Nullpointer [Umbrella]异常

时间:2013-12-14 11:22:43

标签: java gwt nullpointerexception singleton event-bus

我在GWT SimpleEventbus的这个简单实现上被困了几个小时。

此设置有什么问题吗?可能的原因是什么?

我正在使用web.binderyEventbus

import com.google.web.bindery.event.shared.SimpleEventBus;

Eventbus在我的Entrypoint类中被初始化。

public void onModuleLoad() {

    ApplicationEvents = new SimpleEventBus();

然后将它注入Singleton LoadData并注入MainView(UIBinder类没有MVP)。

    LoadData.initLoadData(ApplicationEvents);
    view = new MainView(ApplicationEvents);

initLoadData基本上是构造函数的别名,除了它没有返回任何内容。

public class LoadData {

    private final SimpleEventBus eventBus;

    private LoadData(final SimpleEventBus bus) {
        eventBus = bus;
        ...
    }

    public static void initLoadData(final SimpleEventBus bus){ 
        if (instance == null){
            instance = new LoadData(bus);
        }
    }

将Eventbus注入到MainView中。

public class MainView extends Composite {

    private final SimpleEventBus eventbus;

    public MainView(final SimpleEventBus bus) {
        eventbus = bus;
        ...

然后注册处理程序。

        eventbus.addHandler(EntriesReceiveEvent.TYPE, new EntriesReceiveEventHandler() {
            @Override
            public void onEntriesReceive(EntriesReceiveEvent event) {
            ...
            }
        });

在方法结束时,我让它在LoadData中调用一个方法。

        LoadData.getLoadData().fetchYears(); //alias for loadIndex

LoadData.java

中的loadIndex方法
        private void loadIndex() {
                System.out.println(eventBus.toString());
                if(indexEntries == null){
                    AsyncCallback..
                    public void onSuccess(Map<Short, IndexEntry> result) {
                        eventBus.fireEvent(new EntriesReceiveEvent());
                        //^^ LoadData.java:190

EntriesReceiveEvent.java

import com.google.gwt.event.shared.GwtEvent;

public class EntriesReceiveEvent extends GwtEvent<EntriesReceiveEventHandler> {

      public static Type<EntriesReceiveEventHandler> TYPE = 
              new Type<EntriesReceiveEventHandler>();

    @Override
    public Type<EntriesReceiveEventHandler> getAssociatedType() {
        return TYPE;
    }

    @Override
    protected void dispatch(EntriesReceiveEventHandler handler) {
        handler.onEntriesReceive(this);
    }
}

它是处理程序EntriesReceiveEventHandler.java

import com.google.gwt.event.shared.EventHandler;

public interface EntriesReceiveEventHandler extends EventHandler {

    void onEntriesReceive(EntriesReceiveEvent event);
}

最后是例外。

11:36:57.417 [ERROR] [] Uncaught exception escaped

com.google.web.bindery.event.shared.UmbrellaException: Exception caught: null
at com.google.web.bindery.event.shared.SimpleEventBus.doFire(SimpleEventBus.java:203)
at com.google.web.bindery.event.shared.SimpleEventBus.fireEvent(SimpleEventBus.java:88)
at com.SoftwareEngineering.client.LoadData$2.onSuccess(LoadData.java:190)
at com.SoftwareEngineering.client.LoadData$2.onSuccess(LoadData.java:1)
at com.google.gwt.user.client.rpc.impl.RequestCallbackAdapter.onResponseReceived(RequestCallbackAdapter.java:232)
at com.google.gwt.http.client.Request.fireOnResponseReceived(Request.java:258)
at com.google.gwt.http.client.RequestBuilder$1.onReadyStateChange(RequestBuilder.java:412)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at com.google.gwt.dev.shell.MethodAdaptor.invoke(MethodAdaptor.java:103)
at com.google.gwt.dev.shell.MethodDispatch.invoke(MethodDispatch.java:71)
at com.google.gwt.dev.shell.OophmSessionHandler.invoke(OophmSessionHandler.java:172)
at com.google.gwt.dev.shell.BrowserChannelServer.reactToMessagesWhileWaitingForReturn(BrowserChannelServer.java:338)
at com.google.gwt.dev.shell.BrowserChannelServer.invokeJavascript(BrowserChannelServer.java:219)
at com.google.gwt.dev.shell.ModuleSpaceOOPHM.doInvoke(ModuleSpaceOOPHM.java:136)
at com.google.gwt.dev.shell.ModuleSpace.invokeNative(ModuleSpace.java:571)
at com.google.gwt.dev.shell.ModuleSpace.invokeNativeObject(ModuleSpace.java:279)
at com.google.gwt.dev.shell.JavaScriptHost.invokeNativeObject(JavaScriptHost.java:91)
at com.google.gwt.core.client.impl.Impl.apply(Impl.java)
at com.google.gwt.core.client.impl.Impl.entry0(Impl.java:242)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at com.google.gwt.dev.shell.MethodAdaptor.invoke(MethodAdaptor.java:103)
at com.google.gwt.dev.shell.MethodDispatch.invoke(MethodDispatch.java:71)
at com.google.gwt.dev.shell.OophmSessionHandler.invoke(OophmSessionHandler.java:172)
at com.google.gwt.dev.shell.BrowserChannelServer.reactToMessages(BrowserChannelServer.java:293)
at com.google.gwt.dev.shell.BrowserChannelServer.processConnection(BrowserChannelServer.java:547)
at com.google.gwt.dev.shell.BrowserChannelServer.run(BrowserChannelServer.java:364)
at java.lang.Thread.run(Unknown Source)

我认为Eventbus可能与我不知道他们是否都在使用相同的Eventbus进行通话时相同。然而This site证明了我的担忧是错误的。

附带问题:您是否在此背景下考虑单身人士bad?这是一个相当小的项目,处理所有RPC请求的LoadData需要全局可用。

感谢您的帮助!

1 个答案:

答案 0 :(得分:3)

你在那里的NPE包含在一个伞例外。这意味着其中一个事件处理程序实际上抛出了异常。在这种情况下,标准程序是继续调用其余的处理程序,然后抛出一个伞状异常,其中包含发射时发生的所有错误。

要读取真正的异常,继续向上移动 - 读取发生这种情况的其余日志,并查看处理程序中发生的事情(可能是您自己的事件处理程序代码,或者在你的处理程序调用的一些代码中)。

深入研究这样的问题的另一种方法:使用IDE的调试器并在所有抛出的NullPointerExceptions上设置断点。这将在NPE发生的瞬间暂停调试器,这样您就可以立即看到它而不是挖掘日志。