EventBus使用的简介
写在前面
曾经我们做组件间的消息分发更新,通常会採用观察者模式。或者接口数据回调的相关方式,可是这种做法尽管能够解决我们的问题。可是组件之间的耦合相当严重,并且代码也不易阅读和维护,为了解决这种问题,我们能够使用消息总线EventBus框架。
EventBus是一款针对Android优化的公布/订阅事件总线。主要特点例如以下:替代Intent,Handler,broadcast在Fragment。Activity。Service。线程之间传递消息。开销小,代码优雅,以及将发送者和接受者解耦。
开源地址:https://github.com/greenrobot/EventBus

EventBus简单使用方式(官网给的3步走,我这里细分了5步):
- 1、项目增加依赖。在项目中的build.gradle中增加以下代码:
compile 'org.greenrobot:eventbus:3.0.0'
- 2、定义消息事件对象
public class MessageEventOne {
public final String message;
public MessageEventOne(String message) {
this.message = message;
}
}
- 3、订阅者注冊到EventBUs以及配置事件接受方法
EventBus.getDefault().register(this);
//Declare your subscribing method:
@Subscribe
public void onEvent(AnyEventType event) {/* Do something */};
- 4、公布这发送消息
EventBus.getDefault().post(new MessageEventOne("Hello everyone!"));
- 5、反注冊EventBus
//这个是官网给的反注冊在stop方法中
@Override
public void onStop() {
EventBus.getDefault().unregister(this);
super.onStop();
}
//依据自己的须要,这里我的这个demo中使用的是
@Override
protected void onDestroy() {
super.onDestroy();
EventBus.getDefault().unregister(this);
}
好了。既然有了以上的五步实现方式,那么我们就简单的实现以下吧:
在这里首先提示一点。例如以下图:
看下代码MainActivity.java:
package com.example.eventbusdemo;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
import org.greenrobot.eventbus.EventBus;
import org.greenrobot.eventbus.Subscribe;
import org.greenrobot.eventbus.ThreadMode;
//import de.greenrobot.event.EventBus;
public class MainActivity extends AppCompatActivity {
private Button mButton1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
EventBus.getDefault().register(this);
setContentView(R.layout.activity_main);
initViews();
}
private void initViews() {
mButton1 = (Button) findViewById(R.id.button1);
mButton1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
startActivity(new Intent(MainActivity.this, Main2Activity.class));
}
});
}
/*@Subscribe
public void onMessageEvent(MessageEventOne event) {
Toast.makeText(this, event.message, Toast.LENGTH_SHORT).show();
}*/
/**
* 该方法会在UI线程中运行,接受事件同一时候会在UI线程中运行。这样我们能够在改方法中直接更新UI
*
* @param event
*/
@Subscribe @Subscribe(threadMode = ThreadMode.MAIN)
public void onEventMainThread(MessageEventOne event) {
Toast.makeText(this, "接收到消息:" + event.message, Toast.LENGTH_SHORT).show();
}
/*
@Override
protected void onStop() {
super.onStop();
EventBus.getDefault().unregister(this);
}*/
@Override
protected void onDestroy() {
super.onDestroy();
EventBus.getDefault().unregister(this);
}
}
Main2Activity.java:
package com.example.eventbusdemo;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import org.greenrobot.eventbus.EventBus;
//import de.greenrobot.event.EventBus;
public class Main2Activity extends AppCompatActivity {
private Button button1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2);
initialize();
}
private void initialize() {
button1 = (Button) findViewById(R.id.button1);
button1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Log.d("wuyinlei", "Main2Activity当前线程" + Thread.currentThread()+toString());
EventBus.getDefault().post(new MessageEventOne("Hello everyone!"));
Main2Activity.this.finish();
}
});
}
}
布局代码就更简单了,就有一个button。在这里就不多说了
我们直接看下结果吧:
使用是不是非常easy哈,接下来我们来看下EventBus里面的几个ThreadMode:
POSTING
PostThread :默认的 ThreadMode,表示在运行 Post 操作的线程直接调用订阅者的事件响应方法,
不论该线程是否为主线程(UI 线程)。
当该线程为主线程时,响应方法中不能有耗时操作,
否则有卡主线程的风险。适用场景: 对于是否在主线程运行无要求,但若 Post 线程为主线程。
不能耗时的操作 ;
MAIN
MainThread :在主线程中运行响应方法。假设公布线程就是主线程,则直接调用订阅者的事件响应方法,
否则通过主线程的 Handler 发送消息在主线程中处理——调用订阅者的事件响应函数。
显然。
MainThread 类的方法也不能有耗时操作,以避免卡主线程。
适用场景: 必须在主线程运行的操作 。
BACKGROUND
BackgroundThread :在后台线程中运行响应方法。
假设公布线程 不是 主线程,则直接调用订阅者的
事件响应函数,否则启动 唯一的 后台线程去处理。由于后台线程是唯一的,当事件超过一个的时候。
它们会被放在队列中依次运行,因此该类响应方法尽管没有 PostThread 类和 MainThread 类方法
对性能敏感。但最好不要有重度耗时的操作或太频繁的轻度耗时操作。以造成其它操作等待。适用场景:
操作轻微耗时且不会过于频繁 。即一般的耗时操作都能够放在这里;
ASYNC
Async :不论公布线程是否为主线程,都使用一个空暇线程来处理。和 BackgroundThread 不同的是
, Async 类的全部线程是相互独立的,因此不会出现卡线程的问题。适用场景: 长耗时操作,
比如网络訪问 。
我也试过了。仅仅要指定ThreadMode,方法名字能够自定义的。以下我们来看下怎么使用吧。
我们首先来看下怎么区分是谁发送的消息,这个时候我们在定义一个消息事件对象:
public class MessageEventTwo {
public final String message;
public MessageEventTwo(String message) {
this.message = message;
}
}
我们在Main2Activity中增加一个button。来測试一下:
button2 = (Button) findViewById(R.id.button2);
button2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
EventBus.getDefault().post(new MessageEventTwo("我是第二个消息"));
Main2Activity.this.finish();
}
});
我们来看下运行结果:
能够看到。消息传递是不会混乱的。为什么呢,由于我们在接受消息的时候,已经指定了消息事件
@Subscribe(threadMode = ThreadMode.MAIN)
public void onEventMainThread(MessageEventOne event) {
Toast.makeText(this, "接收到消息:" + event.message, Toast.LENGTH_SHORT).show();
}
@Subscribe(threadMode = ThreadMode.MAIN)
public void onEventMainThread(MessageEventTwo event) {
Toast.makeText(this, "接收到消息:" + event.message, Toast.LENGTH_SHORT).show();
}
在这里说一点,假设没有在接受消息方法上指定,那就是默认的模式,就是在post消息的线程中处理(我刚開始没有指定,測试其它几个的时候,都是在post线程中。找了好久也不知道,最后看了源代码知道了这几个模式 )
@Subscribe(threadMode = ThreadMode.MAIN)还有其它的模式
好了。我们来看下其它几种模式:
/**
* 使用该方法作为订阅函数表示post消息事件和接受消息事件在同一个线程中
*
* @param event
*/
@Subscribe(threadMode = ThreadMode.POSTING)
public void onEvent(MessageEventOne event) {
Log.d("wuyinlei", "onEvent当前线程" + Thread.currentThread() + toString());
//Toast.makeText(this, "接收到消息onEvent:" + event.message, Toast.LENGTH_SHORT).show();
}
/**
* 使用该方法,假设事件在UI线程中发出来。该方法会在子线程中运行,假设是从子线程中发出来消息,该方法会在子线程中运行
*
* @param event
*/
@Subscribe(threadMode = ThreadMode.BACKGROUND)
public void onEventBackgroundThread(MessageEventOne event) {
Log.d("wuyinlei", "onEventBackgroundThread当前线程" + Thread.currentThread() + toString());
// Toast.makeText(this, "接收到消息onEvent:" + event.message, Toast.LENGTH_SHORT).show();
}
/**
* 使用该方法,会在创建新的子线程中运行
*
* @param event
*/
@Subscribe(threadMode = ThreadMode.ASYNC)
public void Async(MessageEventOne event) {
Log.d("wuyinlei", "onEventAsync当前线程" + Thread.currentThread() + toString());
// Toast.makeText(this, "接收到消息onEvent:" + event.message, Toast.LENGTH_SHORT).show();
}
我们来看下log打印吧:
好了,假设想要了解的很多其它,能够去看下源代码哈,假设有问题或者疑问或者见解,能够QQ:1069584784
EventBus使用的简介的更多相关文章
- EventBus详解
EventBus详解 简介 github原文 EventBus... * simplifies the communication between components - decouples eve ...
- Android 框架学习1:EventBus 3.0 的特点与如何使用
前面总结了几篇基础,在这过程中看着别人分享自定义 View.架构或者源码分析,看起来比我写的"高大上"多了,内心也有点小波动. 但是自己的水平自己清楚,基础不扎实画再多源码流程图也 ...
- 安卓巴士android源码、博文精选1
每周精选 第 53 期 精品源码 Android开源项目--CookMan 厨客APP 简介CookMan,厨客,是一款查询.搜索.分类.收藏菜谱功能的APP.|52数据来源Mob A ...
- 【热门技术】EventBus 3.0,让事件订阅更简单,从此告别组件消息传递烦恼~
一.写在前面 还在为时间接收而烦恼吗?还在为各种组件间的消息传递烦恼吗?EventBus 3.0,专注于android的发布.订阅事件总线,让各组件间的消息传递更简单!完美替代Intent,Handl ...
- Android EventBus 3.0.0 使用总结
转载请标明出处:http://www.cnblogs.com/zhaoyanjun/p/6039221.html 本文出自[赵彦军的博客] 前言 EventBus框架 EventBus是一个通用的叫法 ...
- 【转】GitHub 排名前 100 的安卓、iOS项目简介
GitHub Android Libraries Top 100 简介 排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果, 然后过滤了跟 Android 不 ...
- GitHub Android Libraries Top 100 简介
本项目主要对目前 GitHub 上排名前 100 的 Android 开源库进行简单的介绍, 至于排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果, 然后过 ...
- 2016年GitHub 排名前 100 的安卓、iOS项目简介(收藏)
排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果, 然后过滤了跟 Android 不相关的项目, 所以排名并不具备任何官方效力, 仅供参考学习, 方便初学者 ...
- 64.GitHub 排名前100的android项目简介
GitHub Android Libraries Top 100 简介 排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果, 然后过滤了跟 Android 不 ...
随机推荐
- repeater做成gridview【更新删除编辑等】
原文发布时间为:2009-06-14 -- 来源于本人的百度文章 [由搬家工具导入] 不多说,不会说。。看我做的范例。。。 http://download.csdn.net/source/138556 ...
- Atcoder CODE FESTIVAL 2017 qual C D - Yet Another Palindrome Partitioning 回文串划分
题目链接 题意 给定一个字符串(长度\(\leq 2e5\)),将其划分成尽量少的段,使得每段内重新排列后可以成为一个回文串. 题解 分析 每段内重新排列后是一个回文串\(\rightarrow\)该 ...
- hdu 3549 Flow Problem 最大流 Dinic
题目链接 题意 裸的最大流. 学习参考 http://www.cnblogs.com/SYCstudio/p/7260613.html Code #include <bits/stdc++.h& ...
- Python学习杂记_4_分支和循环
分支 和 循环 分支和循环这俩结构在各语言中都有着很重要的地位,当然我之前都没有学好,这里总结一下在Python学习中对这俩结构的认识. 分支结构 # 单分支 if 条件判断: 执行语句… # 双分支 ...
- solr6.6安装
1. 确保系统已经安装jdk1.8,以及Tomcat8. 注:使用Tomcat7会出现很多问题,我遇到的是直接打不开solr的index页面,看网上有网友说还会遇到各种css.js资源404..还有l ...
- Codeforces Gym 101471D Money for Nothing(2017 ACM-ICPC World Finals D题,决策单调性)
题目链接 2017 ACM-ICPC World Finals Problem D (这题细节真的很多) 把所有的(pi,di)按横坐标升序排序. 对于某个点,若存在一个点在他左下角,那么这个点就是 ...
- 服务器出现大量close_wait,我们来说说到底是怎么回事?(以tomcat为例)
一.问题描述 最近一直忙得很,好久没写博客.前两天,微信收到个好友申请,说是想问问close_wait的事情. 找他问了些详细信息,大概了解到,他们后端服务是tomcat 7, jdk 7,cento ...
- 用pid 取主窗口 hwnd
HWND GetHwndByPid(DWORD dwProcessID) { HWND h = GetTopWindow(); HWND retHwnd = NULL; while ( h ) { D ...
- RequireJS解决代码依赖问题,异步加载js,避免页面失去相应
RequireJS的目标是鼓励代码的模块化,它使用了不同于传统<script>标签的脚本加载步骤.可以用它来加速.优化代码,但其主要目的还是为了代码的模块化.它鼓励在使用脚本时以modul ...
- JSONModel解析Dictionary To Model /JSON To Model
你在把字典转成object的时候还在按下面这样: self.id = [jsonDict objectForKey:@"id"]; self.name = [jsonDict ob ...