前言#
之前在聊觀察者模式的時候說過之后要來個EventBus的源碼分析,今天就開始補(bǔ)上。
首先我們做一點準(zhǔn)備工作:
1、下載EventBus的源碼,https://github.com/greenrobot/EventBus。
2、下載完畢之后導(dǎo)入到Android Studio,你會看到總共有5個工程,別驚訝,其實有兩個是測試工程,這里我們不需要,你可以刪掉。
最后只保留了三個工程,EventBus、EventBusAnnotationProcessor、EventBusPerformance。
EventBus這個工程是邏輯層,我們調(diào)用的api都是他定義的。
EventBusAnnotationProcessor是編譯庫,主要用來處理自定義的注解和一些工具類和輔助類的生成。
EventBusPerformance是一個簡單的使用Demo。
所以我們的分析就是從EventBusAnnotationProcessor和EventBus入手。今天我們就先從編譯庫EventBusAnnotationProcessor開始分析。
正文#
首先我們回顧一下EventBusd的用法:
public class MainActivity extends AppCompatActivity {
private TextView textView;
/**
* 接收MessageEvent的處理方法
* */
@Subscribe(threadMode = ThreadMode.MAIN)
public void onMessageEvent(Object object) {
// 如果接收到了多個MessageEvent,可以進(jìn)行區(qū)分
if (object instanceof String){
textView.setText((String) object);
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = (TextView) findViewById(R.id.text);
}
@Override
public void onStart() {
super.onStart();
// 注冊
EventBus.getDefault().register(this);
// 發(fā)送MessageEvent,Object是String類型
EventBus.getDefault().post("test");
}
@Override
public void onStop() {
super.onStop();
// 解綁
EventBus.getDefault().unregister(this);
}
}
使用起來非常的方便,主要是以下幾個步驟:
1、自定義MessageEvent的處理方法。
2、注冊。
3、解綁。
但是有以下幾個問題需要特別注意:
1、EventBus.getDefault().post(111); 這種基本類型是無法響應(yīng)的,因為EventBus只支持對象類型的參數(shù),并且不會自動轉(zhuǎn)換成Integer類型,如果你需要這種操作,需要自己進(jìn)行轉(zhuǎn)換:EventBus.getDefault().post(new Integer(1));
2、可以使用多個參數(shù)的類型不同onMessageEvent,來綁定多個MessageEvent。
3、注解的方法名可以隨意命名。
<h2>StickyEvent</h2>
除了普通的Event,還有一種StickyEvent,它會保存在內(nèi)存中,如果先發(fā)送了Event,再注冊仍然可以接受到,有點類似緩存的機(jī)制。
現(xiàn)在新創(chuàng)建一個SecondActivity:
public class SecondActivity extends Activity {
private TextView textView;
/**
* 接收MessageEvent的處理方法
*/
@Subscribe(sticky = true, threadMode = ThreadMode.MAIN)
public void onMessageEvent(String event) {
// 如果接收到了多個MessageEvent,可以進(jìn)行區(qū)分
textView.setText(textView.getText().toString() + event + "");
}
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = (TextView) findViewById(R.id.text);
}
@Override
public void onStart() {
super.onStart();
// 注冊
EventBus.getDefault().register(this);
}
@Override
public void onStop() {
super.onStop();
// 解綁
EventBus.getDefault().unregister(this);
}
}
非常的簡單,還是注冊,解綁等等,但是在@Subscribe(sticky = true)我們這里使用了StickyEvent,發(fā)送StickyEvent在點擊跳轉(zhuǎn)的時候:
textView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
EventBus.getDefault().postSticky("111");
// 跳轉(zhuǎn)
Intent intent = new Intent(MainActivity.this, SecondActivity.class);
startActivity(intent);
}
});
我們先來預(yù)測一下:
如果是普通的Event,在發(fā)送了之后,再注冊是不會收到這個Event的,那么如果是StickyEvent呢?按照我們剛才的理解,應(yīng)該是會收到的。
看一下截圖:
果然是收到了,這就是StickyEvent的作用。例如我們做了一個顯示手機(jī)電量的應(yīng)用,我們在新的界面,就可以直接拿到已經(jīng)獲得電量的StickyEvent,而不用重新再取一遍。
StickyEvent有幾個特點:
1、同一個類型的StickyEvent,只會保留一個,例如剛才的例子,如果多次EventBus.getDefault().postSticky("111");也只會收到一個。
2、可以手動清除StickyEvent,例如EventBus.getDefault().removeAllStickyEvents();清除掉所有的StickyEvent。
最后要說的是,其實EventBus還可以通過Builder來簡單的配置:
boolean logSubscriberExceptions = true;
boolean logNoSubscriberMessages = true;
boolean sendSubscriberExceptionEvent = true;
boolean sendNoSubscriberEvent = true;
boolean throwSubscriberException;
boolean eventInheritance = true;
boolean ignoreGeneratedIndex;
boolean strictMethodVerification;
ExecutorService executorService = DEFAULT_EXECUTOR_SERVICE;
List<Class<?>> skipMethodVerificationForClasses;
List<SubscriberInfoIndex> subscriberInfoIndexes;
我也是沒看懂這些配置是什么意思,不過不著急,接下來我們?nèi)タ丛创a,這些就全部解決了。
總結(jié)#
其他的就沒什么特別注意的了,我們從使用到現(xiàn)在只發(fā)現(xiàn)了一個注解@Subscribe(threadMode = ThreadMode.MAIN),這個注解用來指定回調(diào)的線程,是否使用StickyEvent,還有接收的優(yōu)先級,那么他是怎么實現(xiàn)這個功能的呢?下一篇我們就來具體看看編譯庫了。
對于編譯框架apt和注解的使用還沒有了解的朋友可以先去看看我之前簡單介紹過的博客:http://blog.csdn.net/u011315960/article/details/62045920。