EventBus框架总结

/*----------------------------------------
 *-描述--EventBus框架总结.
 *-描述--S1.快速集成
 *  SS1.添加依赖 compile ‘org.greenrobot:eventbus:3.0.0‘
 *  SS2.MainAct 注册EventBus EventBus.getDefault().register(this);
 *      onEventMainThread(MyEvent event)获取发送过来的消息
 *  SS3.SubAct发送消息对象,EventBus.getDefault().post(new FirstEvent("new msg..."));
 *-描述--S2.EventBus相关知识
 *  SS1.EventBus是一款针对Android优化的发布/订阅事件总线。主要功能是替代Intent,Handler,BroadCast在
 *  Fragment,Activity,Service,线程之间传递消息.优点是开销小,代码更优雅。以及将发送者和接收者解耦。
 *  SS2.EventBus的四个方法:
 *      @onEvent:如果使用onEvent作为订阅函数,那么该事件在哪个线程发布出来的,onEvent就会在这个线程中运行,
 *      也就是说发布事件和接收事件线程在同一个线程。使用这个方法时,在onEvent方法中不能执行耗时操作,
 *      如果执行耗时操作容易导致事件分发延迟。
 *      @onEventMainThread:如果使用onEventMainThread作为订阅函数,那么不论事件是在哪个线程中发布出来的,
 *      onEventMainThread都会在UI线程中执行,接收事件就会在UI线程中运行,这个在Android中是非常有用的,
 *      因为在Android中只能在UI线程中跟新UI,所以在onEvnetMainThread方法中是不能执行耗时操作的。
 *      @onEventBackground:如果使用onEventBackgrond作为订阅函数,那么如果事件是在UI线程中发布出来的,
 *      那么onEventBackground就会在子线程中运行,如果事件本来就是子线程中发布出来的,那么
 *      onEventBackground函数直接在该子线程中执行。
 *      @onEventAsync:使用这个函数作为订阅函数,那么无论事件在哪个线程发布,都会创建新的子线程在执行
 *      onEventAsync.
 *      @简单总结onEvent-在发布的线程执行,onEventMainThread-在主线程执行,onEventBackground-子线程
 *      中执行,onEventAsync新建一个线程执行。
 *-描述--None.
 *-描述--B1.None.
 *  参考:
 *  https://github.com/greenrobot/EventBus
 *  http://blog.csdn.net/harvic880925/article/details/40660137
 *  http://blog.csdn.net/harvic880925/article/details/40787203
 *  https://segmentfault.com/a/1190000004279679
 *  https://segmentfault.com/a/1190000004314315
 *  http://blog.csdn.net/yuanzeyao/article/details/38174537
 *  http://blog.mcxiaoke.com/2015/08/03/how-to-write-an-eventbus-part1/
 *  异常:
 *  https://github.com/greenrobot/EventBus/issues/271
 *---------------------------------------------------------------------------*/


public class ModxExam1Activity extends BaseActivity implements View.OnClickListener{

//    public ModxExam1Activity() {
//    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_modx_exam1);

        initViews();
        initEvents();
        initDatas();
    }

    @Override
    public void initViews() {
        LogUtil.infoD(this, "initViews");

        /* 注册EventBus */
        EventBus.getDefault().register(this);
        findViewById(R.id.btn_skip).setOnClickListener(this);
    }

    @Override
    public void initEvents() {
        LogUtil.infoD(this, "initEvents");
    }

    @Override
    public void initDatas() {
        LogUtil.infoD(this, "initDatas");
    }

    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.btn_skip:
                Intent intent = new Intent(this,EventBusActivity.class);
                startActivity(intent);
                break;
        }
    }

    /**
     * 在事件发生的线程执行
     * @param event 事件消息对象
     */
    @Subscribe
    public void onEvent(FirstEvent event){
        LogUtil.infoE(this, "onEvent:" + event.getMsg());
    }

    /**
     * 接收消息对象
     * @param event 事件消息对象
     */
    @Subscribe
    public void onEventMainThread(FirstEvent event) {

        String msg = "onEventMainThread:" + event.getMsg();
        LogUtil.infoE(this,msg);
        Toast.makeText(this, msg, Toast.LENGTH_LONG).show();
    }

    /**
     * 在子线程执行
     * @param event 事件消息对象
     */
    @Subscribe
    public void onEventBackgroundThread(FirstEvent event){
        LogUtil.infoE(this, "onEventBackground:" + event.getMsg());
    }

    /**
     * 新建线程执行
     * @param event 事件消息对象
     */
    @Subscribe
    public void onEventAsync(FirstEvent event){
        LogUtil.infoE(this, "onEventAsync:" + event.getMsg());
    }

    @Override
    protected void onDestroy(){
        super.onDestroy();
        /* 取消EventBus注册 */
        EventBus.getDefault().unregister(this);
    }
}
    @Override
    public void onClick(View v) {
        switch (v.getId())
        {
            case R.id.send_btn:
                /* 发送消息对象 */
                EventBus.getDefault().post(new FirstEvent("EventBusActivity btn clicked"));
                break;
        }
    }
时间: 2024-08-10 19:17:12

EventBus框架总结的相关文章

94、EventBus框架 ---- 转载

EventBus使用之基础 http://blog.csdn.net/yanbober/article/details/45667363 EventBus框架库代码走读  http://blog.csdn.net/yanbober/article/details/45671407 EventBus源码解析 带你深入理解EventBus http://blog.csdn.net/lmj623565791/article/details/40920453 EventBus实战 http://blog

Android自助餐之EventBus框架

Android自助餐之EventBus框架 Android自助餐之EventBus框架 下载完整源代码 配置buildgrandle 实例化EventBus 注册事件监听 定义被传递的事件类 发送事件 处理时间 下载完整源代码 配置build.grandle compile 'de.greenrobot:eventbus:2.4.0' 实例化EventBus eventBus=EventBus.builder().build(); 注册事件监听 eventBus.register(this);

EventBus框架库代码走读

PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbober] 本篇继续接上一篇,阅读上一篇EventBus使用之基础 背景 开始分析EventBus前可以下看下EventBus开源框架的工程目录结构: 从上图可以发现,其实EventBus的代码量不是很大,还是很方便入手分析的. 开始分析 通过上一篇基础使用可以发现,使用EventBus框架第一步是得到

EventBus框架源码分析

开源项目 上周又手动撸了一遍EventBus实现,同时上传EventBus的中文注释源码到Github上,欢迎大家fork&star. EventBusAnalysis EventBus 基础概念 EventBus是一个Android事件发布/订阅框架,通过解耦发布者和订阅者简化Android事件传递.事件传递既可以用于Android四大组件间的通讯,也可以用于用户异步线程和主线程间通讯等. 传统的事件传递方法包括:Handler,BroadCastReceiver,interface回调,相比

EventBus框架在Android多Pane(Fragment)中的应用

通常多pane的设计中,比如Fragment A是个Headline,Fragement B是detail,那么B通常需要实现A的点击事件的接口,这样子的话,两个fragment就高耦合了,而且需要在Fragment A中编写一个interface,如果Fragment很多,情景更复杂些,就乱了. 这里可以使用EventBus这个框架,一个典型的发布者-订阅者模式.具体可以参考: https://github.com/greenrobot/EventBus 使用方法大致如下: 这个例子来源于An

Android EventBus框架(二)之源码简单解析

上一篇,我们基本知道了EventBus的使用步骤,接下来先简单研究一下其中的源码.在分析源码之前,我们先回顾一下Java反射的知识点: JAVA反射机制 基本定义: JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制. Sun为提供的关于反射机制中的类: java.lang.Class; java.lang.reflect.Construct

通过EventBus框架GET大牛的框架思维

EventBus的作用 Android中存在各种通信场景,如Activity之间的跳转,Activity与Fragment以及其他组件之间的交互,以及在某个耗时操作(如请求网络)之后的callback回调等,互相之之间往往需要持有对方的引用,每个场景的写法也有差异,导致耦合性较高且不便维护.以Activity和Fragment的通信为例,官方做法是实现一个接口,然后持有对方的引用,再强行转成接口类型,导致耦合度偏高.再以Activity的返回为例,一方需要设置setResult,而另一方需要在o

EventBus 3.0源码解析

现在网上讲解EventBus的文章大多数都是针对2.x版本的,比较老旧,本篇文章希望可以给大家在新版本上面带来帮助. EventBus 是专门为Android设计的用于订阅,发布总线的库,用到这个库的app很多,因为它有很多的优点.比如: 它可以简单Android组件之间的通信 它可以避免了Android四大组件复杂的生命周期处理 它可以让你的代码更为简洁. 先一起了解下如何使用,然后在分析它的源码,知道它的工作原理.我们直接来使用EventBus 3.0,3.x主要的一个新的特性就是使用了注解

EventBus and Broadcast

BroadcastReceiver是什么鬼?在Android中广播分为两个方面:广播发送者和广播接收者,通常情况下,BroadcastReceiver指的就是广播接收者(广播接收器). EventBus又是什么鬼呢?EventBus是一个发布 / 订阅的事件总线.简单点说,就是两人约定好怎么通信,一人发布消息,另外一个约定好的人立马接收到你发的消息.EventBus就可以帮减少很多事,不管 你在任何地方任何位置发布一个事件,接收者都能立马接收到你的消息,不用你考虑android子线程操作UI线程