它的源码地址,可以下载欣赏一下: https://github.com/greenrobot/EventBus
由Greenrobot组织出品的(挺厉害的组织,还出品了GreenDao)
介绍:
EventBus是一种用于Android的发布/订阅事件总线。它有很多优点:简化应用组件间的通信;解耦事件的发送者和接收者;避免复杂和容易出错的依赖和生命周期的问题;很快,专门为高性能优化过等等。
优势:
·简化了组件间的通讯,分离了事件的发送者和接受者
·在Activity、Fragment和线程中表现良好
·避免了复杂和易错的依赖关系和生命周期问题
·更快,更小(约50k的jar包),使得代码更简洁,性能更好
我总结的使用的好处如下3点:
1.不用再写handler和AsynTask更新线程
2.不用写Intent进行类与类之间的传值
3.不用写接口回调进行类和fragment之间的通信
开始使用:
1.添加依赖
implementation 'org.greenrobot:eventbus:3.1.1'
2.写一个用于存参数的对象,这里我传递String类型的参数
/**
* date:2018/11/29
* author:辉(家辉辉辉)
* function:定义消息事件类
*/
public class MessageEvent {
private String message;
public MessageEvent(String message) {
this.message = message;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
}
3.注册
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
...
//注册EventBus
EventBus.getDefault().register(this);
}
4.销毁,这里可以不用判断的可以观察下源码,我写的优点谨慎了
@Override
protected void onDestroy() {
super.onDestroy();
//判断是不是注册过,注册过true,否则false
if (EventBus.getDefault().isRegistered(this)) {
//解除注册
EventBus.getDefault().unregister(this);
}
}
5.要写一个新的Activity进行参数的传递
6.begin,一个点击事件
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn_second_activity://进行跳转
Intent intent = new Intent(MainActivity.this, SecondActivity.class);
startActivity(intent);
break;
}
}
7.在新的Activity中进行传值,不需要注册,因为这个类不用
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn_main_activity:
EventBus.getDefault().post(new MessageEvent("哈哈成了"));
finish();
break;
}
}
8.最后一步,进行参数的赋值
//接收数据设置数据
@Subscribe(threadMode = ThreadMode.MAIN)
public void event(MessageEvent messageEvent){
verify_text.setText(messageEvent.getMessage());
}
这里一定要加入注解,这样的注解一共有四个,我都打印了log供参考
@Subscribe(threadMode = ThreadMode.MAIN)
public void event(MessageEvent messageEvent){
String name = Thread.currentThread().getName();
Log.e("wjh", "MAIN: "+name);
}
@Subscribe(threadMode = ThreadMode.POSTING)
public void event_two(MessageEvent messageEvent){
String name = Thread.currentThread().getName();
Log.e("wjh", "POSTING: "+name);
}
@Subscribe(threadMode = ThreadMode.ASYNC)
public void event_three(MessageEvent messageEvent){
String name = Thread.currentThread().getName();
Log.e("wjh", "ASYNC: "+name);
}
@Subscribe(threadMode = ThreadMode.BACKGROUND)
public void event_f(MessageEvent messageEvent){
String name = Thread.currentThread().getName();
Log.e("wjh", "BACKGROUND: "+name);
}
分别在主线程和子线程打印了一下结果如下:
第一种情况如果在主线程中,四种注解运行的线程名:
第二种情况在子线程
主要在开发中用到的就是MAIN和BACKGROUND
MAIN:主要是做线程更新和通信,传值
POSTIONG:表示该方法和消息发送方在同一个线程.
ASYNC:表示无论发送方是在子线程还是在主线程,都会开一个新的子线程去运行,适用于多 个线程任务,内部有线程池管理,比如请求网络时,用这个方法,他会自动创建方法去请求,可以异步并发处理
BACKGROUND:表示该方法在后台运行(也就是子线程),不能够并发处理,如果发布者在子线程,那么该方法就在子线程执行。如果发布者在主线程,那么该方法就会创建一个子线程,在子线程运行。