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