EventBus是一个常用的消息框架,可以方便用于的跨组件之间的消息传递,比起官方提供的Handler,有着不需要考虑内存泄露、不需要写处理消息事件的回调、支持粘性事件、线程调度高效灵活等优点。
EventBus的使用非常简单,首先需要定义一个消息类(Event),只需要在发送消息的组件发送消息(post),在接受消息的组件(订阅者)定义一个入参为此消息类的公共方法,并添加订阅注解(Subscribe),在发送的消息传递到订阅者组件时就会调用此方法,有点类似于观察者模式。订阅者和消息的发送者需要保证在消息的传输过程中处于生命周期的存活阶段,如果发送消息时订阅者尚未被初始化,需要将消息设置为粘性事件(sticky),这样的消息在组件初始化后即可接收并处理,可以避免消息遗漏。消息的发送者需要在创建阶段执行注册(register),在销毁阶段执行注销(unregister)。EventBus也有缺点,比如频繁使用会创建大量的事件类。相关教程比较多,这里不再赘述。
这里仿照EventBus的思想,写一个简易的消息传递工具类。
创建一个订阅注解,持久度为运行时,注解对象为方法。
package tinybus.annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
public @interface Subscribe {
String goal() default ""; //目的地
}
因为是简化版本的EventBus,暂时叫TinyBus吧(因为体积非常小),支持空消息类发送,所以逻辑都精简在一个类中,主打一个简单易用。
package tinybus;
import tinybus.annotation.Subscribe;
import java.lang.annotation.Annotation;
imp