刚開始是从otto入手,可是otto不支持异步运行。所以后来才開始研究了Event Bus。关于Event Bus,先前搜索的时候,看到网上的实例,非常碎,并且非常多都是一样的内容,代码看下来基本上是分2套写法。这就带来了疑问。后来再细致浏览原先的帖子发现了Event Bus有2套源代码。一个是greenrobot的Event Bus,一个是google的guava Event Bus。今天谈论的并非2套Event Bus的原理以及不同之处,这些内容基本在网上都有參考,临时不在这里累赘介绍了。等有时间深入研究的时候能够再写一遍具体的Event
Bus的介绍。这次基本的是介绍2套Event Bus的异步实现,网上中文页面搜索基本非常少有Event Bus异步的介绍,有的话也是非常easy的代码实例,并且仅仅有抛事件的代码,尝试过后都是失败的,最后都是在外文站点上搜索到了关键的代码,好了不废话。直接上代码。

首先介绍的是greenrobot Event Bus

package com.benny.test;





import java.util.ArrayList;

import java.util.List;





import android.app.Activity;

import android.graphics.Color;

import android.os.Bundle;

import android.util.Log;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

import android.widget.LinearLayout;

import android.widget.LinearLayout.LayoutParams;

import android.widget.TextView;

import de.greenrobot.event.EventBus;





public class MyEventByusTestActivity extends Activity implements OnClickListener {



private EventBus eventBus = EventBus.getDefault();

private LinearLayout viewGroup;



    /** Called when the activity is first created. */

    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        viewGroup = (LinearLayout)findViewById(R.id.main_layout);

// button设置响应接口

        findViewById(R.id.postthread).setOnClickListener(this);

        findViewById(R.id.mainthread).setOnClickListener(this);

        findViewById(R.id.backgroundthread).setOnClickListener(this);

        findViewById(R.id.async).setOnClickListener(this);

    }





@Override

protected void onPause() {

super.onPause();

// 注销事件响应

eventBus.unregister(this);

}





@Override

protected void onResume() {

super.onResume();

// 注冊事件响应

eventBus.register(this);

}





@Override

public void onClick(View v) {

switch (v.getId()) {

case R.id.postthread:

// 抛出PostThread模式的LoadButtonEvent事件

eventBus.post(loadButtonList("postthread", 30));

break;

case R.id.mainthread:

// 抛出MainThread模式的LoadLineEvent事件

eventBus.post(loadLineList(20));

break;

case R.id.backgroundthread:

// 抛出BackgroundThread模式的LoadNoneEvent事件

eventBus.post(new LoadNoneEvent());

break;

case R.id.async:

// 抛出Async模式的LoadAsyEvent事件

eventBus.post(new LoadAsyEvent());

break;

default:

break;

}

}

    

public LoadEvent loadTextList(String str, int num) {

ArrayList<TextView> list = new ArrayList<TextView>(num);

for (int i = 0; i < num; i++) {

TextView textView = new TextView(this);

textView.setText(str + i);

list.add(textView);

}

return new LoadEvent(list);

}



public LoadLineEvent loadLineList(int num) {

ArrayList<View> list = new ArrayList<View>();

for (int i = 0; i < num; i++) {

View view = new View(this);

view.setBackgroundColor(Color.BLUE);

list.add(view);

}

return new LoadLineEvent(list);

}



public LoadButtonEvent loadButtonList(String str, int num) {

ArrayList<Button> list = new ArrayList<Button>();

for (int i = 0; i < num; i++) {

Button button = new Button(this);

button.setText(str + i);

list.add(button);

}

return new LoadButtonEvent(list);

}

// 以PostThread的方式接受LoadButtonEvent事件

public void onEvent(LoadButtonEvent event) {

Log.d("EventBus", "load post thread");

addButtonViews(event);

}

// 以MainThread的方式接受LoadLineEvent事件

public void onEventMainThread(LoadLineEvent event) {

Log.d("EventBus", "load main thread");

addLineViews(event);

}

// 以BackgroundThread的方式接受LoadNoneEvent事件

public void onEventBackgroundThread(LoadNoneEvent event) {

Log.d("EventBus", "load background thread");

LoadEvent loadE = loadTextList("backgroundthread", 500);

// 抛出MainThread模式的LoadEvent事件用来更新界面

eventBus.post(loadE);

}

// 以Async的方式接受LoadAsyEvent事件

public void onEventAsync(LoadAsyEvent event) {

Log.d("EventBus", "load async");

LoadEvent loadE = loadTextList("async", 1000);

// 抛出MainThread模式的LoadEvent事件用来更新界面

eventBus.post(loadE);

}

// 以MainThread的方式接受LoadEvent事件

public void onEventMainThread(LoadEvent event) {

addTextViews(event);

}



private void addLineViews(LoadLineEvent event) {

viewGroup.removeAllViews();

for (View view : event.list) {

LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT, 20);

viewGroup.addView(view, param);

}

}



private void addButtonViews(LoadButtonEvent event) {

viewGroup.removeAllViews();

for (Button button : event.list) {

LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);

viewGroup.addView(button, param);

}

}



private void addTextViews(LoadEvent event) {

viewGroup.removeAllViews();

for (TextView view : event.list) {

LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);

viewGroup.addView(view, param);

}

}

class LoadEvent {



List<TextView> list;



public LoadEvent(List<TextView> list) {

this.list = list;

}

}



class LoadLineEvent {



List<View> list;



public LoadLineEvent (List<View> list) {

this.list = list;

}

}



class LoadButtonEvent {



List<Button> list;



public LoadButtonEvent(List<Button> list) {

this.list = list;

}

}



class LoadNoneEvent {



}



class LoadAsyEvent {



}

}

界面事实上非常easy。四个button,分别为R.id.postthread,R.id.mainthread,R.id.backgroundthread,R.id.async。这个是分别针对Event Bus中ThreadMode的四种模式:PostThread,MainThread,BackgroundThread,Async。

PostThread —— 直接将事件抛在当前的线程中。

MainThread —— 将事件抛在主线程中(UI线程)。

BackgroundThread —— 将事件抛在新的线程中。

Async —— 将事件抛在异步线程中。

viewGroup是一个在ScrollView以下的LinearLayout布局。

greenrobot Event Bus,其固定的接受事件代码是

public void onEvent(AnyEvent event) -- PostThread

public void onEventMainThread(AnyEvent event) -- MainThread

public void onEventBackgroundThread(AnyEvent event) -- BackgroundThread

public void onEventAsync(AnyEvent event) -- Async

事实上另一种方法,能够直接定义事件接受的方法。

可查看EventBus中的代码 public void register(Object subscriber, String methodName, Class<?> eventType, Class<?>... moreEventTypes)

methodName -- 能够是自定义的方法名,能够全然代替"onEvent",至于4种模式相同能够区分,methodName仅仅须要前缀。譬如传递的參数是loadEvent。而代码中的方法是public void loadEventAsync(AnyEvent event),则表示是通过Async抛出的事件。以此类推。

Class<?> eventType, Class<?>... moreEventTypes -- 是于事件相关的一些參数。

也能够通过阅读EventBus的源代码来获取很多其它的信息。

在BackgroundThread,Async模式中,最后假设要刷新界面的话。他们还是须要在以MainThread的模式抛出刷新界面的事件。

greenrobot Event Bus下载地址:https://github.com/greenrobot/EventBus

接着介绍guava Event Bus。

package com.benny.test;





import java.util.concurrent.Executor;





import android.app.Activity;

import android.os.Bundle;

import android.os.Handler;

import android.os.Looper;

import android.util.Log;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

import android.widget.LinearLayout;

import android.widget.LinearLayout.LayoutParams;

import android.widget.TextView;





import com.google.common.eventbus.AsyncEventBus;

import com.google.common.eventbus.EventBus;

import com.google.common.eventbus.Subscribe;





public class GuavaEventBusDemoActivity extends Activity implements OnClickListener {

// 创建异步的EventBus

private EventBus asyBus = new AsyncEventBus(new Executor() {



private Handler mHandler;

// 实现异步机制的事件处理

@Override

public void execute(Runnable command) {

if (mHandler == null) {

mHandler = new Handler(Looper.getMainLooper());

}

mHandler.post(command);

}



});

private EventBus bus = new EventBus();

private LinearLayout viewGroup;





    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        viewGroup = (LinearLayout)findViewById(R.id.main_layout);

        findViewById(R.id.postthread).setOnClickListener(this);

        findViewById(R.id.mainthread).setOnClickListener(this);

        findViewById(R.id.backgroundthread).setOnClickListener(this);

        findViewById(R.id.async).setOnClickListener(this);

    }

    

@Override

protected void onPause() {

super.onPause();

// 注销事件订阅者

bus.unregister(this);

asyBus.unregister(this);

}





@Override

protected void onResume() {

super.onResume();

// 注冊事件订阅者

bus.register(this);

asyBus.register(this);

}









@Override

public void onClick(View v) {

switch (v.getId()) {

case R.id.postthread:

break;

case R.id.mainthread:

// 主线程抛LoadButtonEvent事件

bus.post(new LoadButtonEvent("main thread", 100));

break;

case R.id.backgroundthread:

break;

case R.id.async:

// 异步线程抛LoadTextEvent事件

asyBus.post(new LoadTextEvent("async", 1000));

break;

default:

break;

}

}

// 订阅LoadButtonEvent事件处理

@Subscribe

public void loadButtonList(LoadButtonEvent event) {

Log.d("Guava", "ButtonEvent" + event);

viewGroup.removeAllViews();

for (int i = 0; i < event.num; i++) {

Button button = new Button(this);

button.setText(event.str + i);

LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);

viewGroup.addView(button, param);

}

}

// 订阅LoadTextEvent事件处理

@Subscribe

public void loadTextListAsync(LoadTextEvent event) {

Log.d("Guava", "TextEvent=" + event.str);

viewGroup.removeAllViews();

for (int i = 0; i < event.num; i++) {

TextView textView = new TextView(this);

textView.setText(event.str + i);

LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);

viewGroup.addView(textView, param);

}

}



class LoadButtonEvent {

String str;

int num;



public LoadButtonEvent(String str, int num) {

this.str = str;

this.num = num;

}

}



class LoadTextEvent {

String str;

int num;



public LoadTextEvent(String str, int num) {

this.str = str;

this.num = num;

}

}



}

界面跟上一个实例是一样的,只是仅仅用到了2个button。MainThread和Asyncbutton。viewGroup是一个在ScrollView以下的LinearLayout布局。

异步的关键就在于

private EventBus asyBus = new AsyncEventBus(new Executor() {



private Handler mHandler;

// 实现异步机制的事件处理

@Override

public void execute(Runnable command) {

if (mHandler == null) {

mHandler = new Handler(Looper.getMainLooper());

}

mHandler.post(command);

}



});

这样能够直接在异步事件后刷新界面。

guava Event Bus 下载地址:https://code.google.com/p/guava-libraries/

综合以上2个实例,这两种Event Bus的各自长处也非常明显,greenrobot Event Bus有四种模式抛出事件。guava Event Bus的异步实现比greenrobot来的方便,无需再抛MainThread事件了。源代码就不上了。大家动手写写能够加深印象。

&lt;Android&gt;greenrobot-EventBus,guava-Event Bus的异步实现的更多相关文章

  1. spring集成guava的event bus

    Guava的event bus guava, https://github.com/google/guava 是一个非常有名的Java类库,提供了很多在日常开发中常用的集合.函数接口等.此外,guav ...

  2. EventBus / Event Bus

    EventBus / Event Bus EventEmitter / Event Emitter https://greenrobot.org/eventbus/documentation/ htt ...

  3. 推荐 greenrobot eventbus,简化安卓开发,提高安卓维护性,优化安卓性能

    最近在研究移动开发,广泛的阅读有关cordova,apicloud,android资料.发现安卓的开发还是很简单的.再发现greenrobot eventbus开源框架不仅可以简化安卓开发,有可以大幅 ...

  4. Android消息传递之EventBus 3.0使用详解

    前言: 前面两篇不仅学习了子线程与UI主线程之间的通信方式,也学习了如何实现组件之间通信,基于前面的知识我们今天来分析一下EventBus是如何管理事件总线的,EventBus到底是不是最佳方案?学习 ...

  5. Android中的eventBus传值

    第一步:在build.gradle中添加依赖dependencies { compile 'org.greenrobot:eventbus:3.0.0'} 第二步:创建一个 Event类: 注意:en ...

  6. Android中的EventBus

    1.分析 EventBus是一个针对Android的事件发布和订阅的框架,主要功能是替代Intent,Handler,BroadCast在Fragment,Activity,Service,线程之间传 ...

  7. Android框架之EventBus的使用

    简介 EventBus是由greenrobot组织贡献的一个Android事件发布/订阅的轻量级框架.EventBus是一个Android端优化的publish/subscribe消息总线,简化了应用 ...

  8. 事件总线(Event Bus)知多少

    源码路径:Github-EventBus 简书同步链接 1. 引言 事件总线这个概念对你来说可能很陌生,但提到观察者(发布-订阅)模式,你也许就很熟悉.事件总线是对发布-订阅模式的一种实现.它是一种集 ...

  9. 事件总线(Event Bus)

    事件总线(Event Bus)知多少 源码路径:Github-EventBus简书同步链接 1. 引言 事件总线这个概念对你来说可能很陌生,但提到观察者(发布-订阅)模式,你也许就很熟悉.事件总线是对 ...

随机推荐

  1. 剑指Offer整理笔记

    说在前面,本篇的目的是为了学习剑指offer,以及博客园的排版功能,并将文章排版得整洁得体. 梵蒂冈梵蒂冈地方官方

  2. [LUOGU] P3871 [TJOI2010]中位数

    题目描述 给定一个由N个元素组成的整数序列,现在有两种操作: 1 add a 在该序列的最后添加一个整数a,组成长度为N + 1的整数序列 2 mid 输出当前序列的中位数 中位数是指将一个序列按照从 ...

  3. PyQt5-Python3-PyCharm 配置

    File->Tools->External Tools->add 配置ui文件转换工具 Name: PyUIC Program: D:\develop\python\Mac\venv ...

  4. (8) openssl rsautl(签名/验证签名/加解密文件)和openssl pkeyutl(文件的非对称加密)

    rsautl是rsa的工具,相当于rsa.dgst的部分功能集合,可用于生成数字签名.验证数字签名.加密和解密文件. pkeyutl是非对称加密的通用工具,大体上和rsautl的用法差不多,所以此处只 ...

  5. JDBC-Web项目导入mysql驱动包路径-Eclipse & Myeclipse

    初学JAVA,很多都不懂,开始听老师说导入数据库驱动包的时候是: 右键项目 -> Properties -> Java Build Path -> 右侧选项卡选择Libraries ...

  6. 微信小程序request请求动态获取数据

    微信小程序开发文档链接 1 后台代码: clickButton:function(){ var that = this; wx.request({ url: 'http://localhost:909 ...

  7. h5 页面 禁止网页缩放

    //禁用双指缩放: document.documentElement.addEventListener('touchstart', function (event) { if (event.touch ...

  8. Android开发——获取应用数据/缓存大小并清理缓存

    1. 获取应用数据/缓存大小 其中pm为实例化的PackageManager,因为需要遍历所有的已安装的应用.因此需要开启子线程进行处理. 还有需要注意的是,在Android4.2之前getPacka ...

  9. Android开发——短信电话拦截/接听电话

    1.短信拦截 首先需要声明的是,Android4.4版本以上,如果想做到短信拦截,必须成为default sms,把所有短信相关的功能都包揽了,然后再做短信拦截.但这种做法,适配性和兼容性的工作是非常 ...

  10. tarjan 学习记

    1.强连通分量是什么 强连通分量指的是部分点的集合如果能够互相到达(例如 1→3,3→2,2→1(有向图)这种,132每个点都能互相抵达) 或者说,有一个环,环上点的集合就是一个强连通分量 2.那怎么 ...