Guava EventBus體驗

EventBus初體驗

1. 簡介

EventBus是Guava提供的總線事件庫,可實現進程內發佈訂閱功能;
EventBus自動把事件分發給事件超類的監聽者,並且允許監聽者聲明監聽接口類型和泛型的通配符類型;
EventBus涉及到的角色有:
- 消息生產者
- 消息監聽者
- 角色管理平臺

2 EventBus主要接口

接口 功能說明
register(Object object) 註冊消息監聽者
unregister(Object object) 移除消息監聽者
post(Object object) 消息生產者發佈消息

3. 代碼demo

3.0 消息體

自定義一個消息類型Person,方便後續測試;

public class Person {

    private String name;
    private String address;
    private String sex;

    /**
     * 省略getter/setter方法
     */
}

3.1 角色管理平臺

角色管理平臺核心就是一個EventBus對象,並封裝EventBus的主要接口對外提供。

public class EventBusManager {

    // 創建guava提供的EventBus對象
    private static EventBus eventBus = new EventBus();

    //————————單例模式————————
    private EventBusManager() { }

    private static final class InstanceHolder {
        private static final EventBusManager INSTANCE = new EventBusManager();
    }

    public static EventBusManager getInstance() {
        return InstanceHolder.INSTANCE;
    }

    /**
     * 註冊監聽者
     * @param o
     */
    public void register(Object o){
        eventBus.register(o);
    }

    /**
     * 移除監聽者
     * @param o
     */
    public void unregister(Object o) {
        eventBus.unregister(o);
    }

    /**
     * 消息發佈接口
     * @param o
     */
    public void post(Object o) {
        eventBus.post(o);
    }
}

3.2 消息監聽者

監聽者需要通過@Subscribe來聲明消息處理方式,支持泛型。

public class Subscriber<T> {

    @Subscribe
    public void out(T t){
        if (t instanceof MsgDTO) {
            MsgDTO dto = (MsgDTO) t;
           System.out.println(dto.getName());
            return;
        }
        System.out.println(t.toString());
    }
}

3.3 消息生產者

生產者發佈消息之前需要先將消息監聽者綁定到EventBus,然後才能保證消息被正確監聽。

public class Main {

    public static void main(String[] args) {
        MsgDTO msgDTO = new MsgDTO();
        msgDTO.setName("測試消息體");

        // 先綁定消息監聽者
        EventBusManager.getInstance().register(new Subscriber());
        EventBusManager.getInstance().post(msgDTO);
        EventBusManager.getInstance().post(new Integer(12345645));
        EventBusManager.getInstance().post("直接測試字符串");
        EventBusManager.getInstance().post(1234);
    }
}

3.4 測試結果

測試消息體
12345645
直接測試字符串
1234
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章