EventBus是一款針對Android優化的發佈/訂閱事件總線。主要功能是替代Intent,Handler,BroadCast在Fragment,Activity,Service,線程之間傳遞消息.優勢是開銷小,代碼更優雅。以及將發送者和接收者解耦。html
//經過反射,獲取到訂閱者的全部方法
Method[] methods = clazz.getMethods();
for (Method method : methods) { String methodName = method.getName(); //只找以onEvent開頭的方法 if (methodName.startsWith(eventMethodName)) { int modifiers = method.getModifiers(); //判斷訂閱者是不是public的,而且是否有修飾符,看來訂閱者只能是public的,而且不能被final,static等修飾 if ((modifiers & Modifier.PUBLIC) != 0 && (modifiers & MODIFIERS_IGNORE) == 0) { //得到訂閱函數的參數 Class<?>[] parameterTypes = method.getParameterTypes(); //看了參數的個數只能是1個 if (parameterTypes.length == 1) { //獲取onEvent後面的部分 String modifierString = methodName.substring(eventMethodName.length()); ThreadMode threadMode; if (modifierString.length() == 0) { //訂閱函數爲onEvnet //記錄線程模型爲PostThread,意義就是發佈事件和接收事件在同一個線程執行,詳細能夠參考我對於四個訂閱函數不一樣點分析 threadMode = ThreadMode.PostThread; } else if (modifierString.equals("MainThread")) { //對應onEventMainThread threadMode = ThreadMode.MainThread; } else if (modifierString.equals("BackgroundThread")) { //對應onEventBackgrondThread threadMode = ThreadMode.BackgroundThread; } else if (modifierString.equals("Async")) { //對應onEventAsync threadMode = ThreadMode.Async; } else { if (skipMethodVerificationForClasses.containsKey(clazz)) { continue; } else { throw new EventBusException("Illegal onEvent method, check for typos: " + method); } } //獲取參數類型,其實就是接收事件的類型 Class<?> eventType = parameterTypes[0]; methodKeyBuilder.setLength(0); methodKeyBuilder.append(methodName); methodKeyBuilder.append('>').append(eventType.getName()); String methodKey = methodKeyBuilder.toString(); if (eventTypesFound.add(methodKey)) { // Only add if not already found in a sub class //封裝一個訂閱方法對象,這個對象包含Method對象,threadMode對象,eventType對象 subscriberMethods.add(new SubscriberMethod(method, threadMode, eventType)); } } } else if (!skipMethodVerificationForClasses.containsKey(clazz)) { Log.d(EventBus.TAG, "Skipping method (not public, static or abstract): " + clazz + "." + methodName); } } } //看了還會遍歷父類的訂閱函數 clazz = clazz.getSuperclass(); } //最後加入緩存,第二次使用直接從緩存拿 if (subscriberMethods.isEmpty()) { throw new EventBusException("Subscriber " + subscriberClass + " has no public methods called " + eventMethodName); } else { synchronized (methodCache) { methodCache.put(key, subscriberMethods); } return subscriberMethods; } }
更多源碼見:http://www.tuicool.com/articles/jUvyUjBjava
一、下載EventBus的類庫
源碼:https://github.com/greenrobot/EventBusandroid
二、基本使用git
(1)自定義一個類,能夠是空類,好比:github
(2)在要接收消息的頁面註冊:緩存
(3)發送消息app
(4)接受消息的頁面實現(共有四個函數,各功能不一樣,這是其中之一,能夠選擇性的實現,這裏先實現一個):框架
(5)解除註冊ide
順序就是這麼個順序,可真正讓本身寫,估計仍是雲裏霧裏的,下面舉個例子來講明下。函數
首先,在EventBus中,獲取實例的方法通常是採用EventBus.getInstance()來獲取默認的EventBus實例,固然你也能夠new一個又一個,我的感受仍是用默認的比較好,以防出錯。
先給你們看個例子:
當擊btn_try按鈕的時候,跳到第二個Activity,當點擊第二個activity上面的First Event按鈕的時候向第一個Activity發送消息,當第一個Activity收到消息後,一方面將消息Toast顯示,一方面放入textView中顯示。
按照下面的步驟,下面來建這個工程:
想必你們從一個Activity跳轉到第二個Activity的程序應該都會寫,這裏先稍稍把兩個Activity跳轉的代碼建起來。後面再添加EventBus相關的玩意。
MainActivity佈局(activity_main.xml)
新建一個Activity,SecondActivity佈局(activity_second.xml)
MainActivity.java (點擊btn跳轉到第二個Activity)
到這,基本框架就搭完了,下面開始按步驟使用EventBus了。
這個類很簡單,構造時傳進去一個字符串,而後能夠經過getMsg()獲取出來。
在上面的GIF圖片的演示中,你們也能夠看到,咱們是要在MainActivity中接收發過來的消息的,因此咱們在MainActivity中註冊消息。
經過咱們會在OnCreate()函數中註冊EventBus,在OnDestroy()函數中反註冊。因此總體的註冊與反註冊的代碼以下:
發送消息是使用EventBus中的Post方法來實現發送的,發送過去的是咱們新建的類的實例!
完整的SecondActivity.Java的代碼以下:
接收消息時,咱們使用EventBus中最經常使用的onEventMainThread()函數來接收消息,具體爲何用這個,咱們下篇再講,這裏先給你們一個初步認識,要先能把EventBus用起來先。
在MainActivity中重寫onEventMainThread(FirstEvent event),參數就是咱們本身定義的類:
在收到Event實例後,咱們將其中攜帶的消息取出,一方面Toast出去,一方面傳到TextView中;
完整的MainActiviy代碼以下:
好了,到這,基本上算初步把EventBus用起來了,下篇再講講EventBus的幾個函數,及各個函數間是如何識別當前如何調用哪一個函數的。
若是個人文章有幫到你,請關注哦。
源碼地址:http://download.csdn.net/detail/harvic880925/8111357
請你們尊重原創者版權,轉載請標明出處:http://blog.csdn.net/harvic880925/article/details/40660137 謝謝!