EventBus使用详解和它其中的4种注解对比

它的源码地址,可以下载欣赏一下: 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:表示该方法在后台运行(也就是子线程),不能够并发处理,如果发布者在子线程,那么该方法就在子线程执行。如果发布者在主线程,那么该方法就会创建一个子线程,在子线程运行。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
EventBus是一个开源的发布/订阅事件总线库,它简化了不同组件之间的通信,避免了紧密耦合的代码。它使用了观察者模式,让不同的组件能够在没有直接关联的情况下相互通信。下面是EventBus在Android中的使用详解。 1.导入EventBus库 在build.gradle文件中添加以下代码: ``` dependencies { implementation 'org.greenrobot:eventbus:3.2.0' } ``` 2.定义事件类 定义一个事件类,用于传递数据。 ```java public class MessageEvent { public final String message; public MessageEvent(String message) { this.message = message; } } ``` 3.注册EventBus 在需要接收事件的组件中注册EventBus。 ```java @Override public void onStart() { super.onStart(); EventBus.getDefault().register(this); } ``` 4.注销EventBus 在不需要接收事件的组件中注销EventBus。 ```java @Override public void onStop() { super.onStop(); EventBus.getDefault().unregister(this); } ``` 5.发布事件 在发送事件的组件中发布事件。 ```java EventBus.getDefault().post(new MessageEvent("Hello EventBus!")); ``` 6.订阅事件 在接收事件的组件中订阅事件。 ```java @Subscribe(threadMode = ThreadMode.MAIN) public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } ``` 7.指定线程模式 EventBus支持在不同的线程中处理事件,可以通过@Subscribe注解的threadMode参数指定线程模式。 ```java @Subscribe(threadMode = ThreadMode.MAIN) // 主线程 public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } @Subscribe(threadMode = ThreadMode.BACKGROUND) // 后台线程 public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } @Subscribe(threadMode = ThreadMode.ASYNC) // 异步线程 public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } ``` EventBus使用非常简单,但是需要注意以下几点: - 订阅方法必须使用@Subscribe注解,并且方法必须是public、void类型。 - 发布事件和接收事件的参数类型必须一致。 - 在注册EventBus时,不要忘记在onStop()方法中注销EventBus,否则可能会引起内存泄漏。 - EventBus默认在主线程中处理事件,如果事件处理需要耗时操作,可以使用不同的线程模式。 - EventBus不支持跨进程通信,只能在同一进程中的组件之间进行通信。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值