您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關如何使用RxJava實現事件總線Event Bus的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
示例:
public class RxBus { private static volatile RxBus defaultInstance; private final Subject<Object, Object> bus; // PublishSubject只會把在訂閱發生的時間點之后來自原始Observable的數據發射給觀察者 public RxBus() { bus = new SerializedSubject<>(PublishSubject.create()); } // 單例RxBus public static RxBus getDefault() { if (defaultInstance == null) { synchronized (RxBus.class) { if (defaultInstance == null) { defaultInstance = new RxBus(); } } } return defaultInstance ; } // 發送一個新的事件 public void post (Object o) { bus.onNext(o); } // 根據傳遞的 eventType 類型返回特定類型(eventType)的 被觀察者 public <T> Observable<T> toObservable (Class<T> eventType) { return bus.ofType(eventType); // 這里感謝小鄧子的提醒: ofType = filter + cast // return bus.filter(new Func1<Object, Boolean>() { // @Override // public Boolean call(Object o) { // return eventType.isInstance(o); // } // }) .cast(eventType); } }
注:
1、Subject同時充當了Observer和Observable的角色,Subject是非線程安全的,要避免該問題,需要將 Subject轉換為一個 SerializedSubject ,上述RxBus類中把線程非安全的PublishSubject包裝成線程安全的Subject。
2、PublishSubject只會把在訂閱發生的時間點之后來自原始Observable的數據發射給觀察者。
3、ofType操作符只發射指定類型的數據,其內部就是filter+cast(這里非常感謝@小鄧子 的提醒)
public final <R> Observable<R> ofType(final Class<R> klass) { return filter(new Func1<T, Boolean>() { @Override public final Boolean call(T t) { return klass.isInstance(t); } }).cast(klass); }
filter操作符可以使你提供一個指定的測試數據項,只有通過測試的數據才會被“發射”。
cast操作符可以將一個Observable轉換成指定類型的Observable。
分析:
RxBus工作流程圖
1、首先創建一個可同時充當Observer和Observable的Subject;
2、在需要接收事件的地方,訂閱該Subject(此時Subject是作為Observable),在這之后,一旦Subject接收到事件,立即發射給該訂閱者;
3、在我們需要發送事件的地方,將事件post至Subject,此時Subject作為Observer接收到事件(onNext),然后會發射給所有訂閱該Subject的訂閱者。
對于RxBus的使用,就和普通的RxJava訂閱事件很相似了。
先看發送事件的代碼:
RxBus.getDefault().post(new UserEvent (1, "yoyo"));
userEvent是要發送的事件,如果你用過EventBus, 很容易理解,UserEvent的代碼:
public class UserEvent { long id; String name; public UserEvent(long id,String name) { this.id= id; this.name= name; } public long getId() { return id; } public String getName() { return name; } }
再看接收事件的代碼:
// rxSubscription是一個Subscription的全局變量,這段代碼可以在onCreate/onStart等生命周期內 rxSubscription = RxBus.getDefault().toObserverable(UserEvent.class) .subscribe(new Action1<UserEvent>() { @Override public void call(UserEvent userEvent) { long id = userEvent.getId(); String name = userEvent.getName(); ... } }, new Action1<Throwable>() { @Override public void call(Throwable throwable) { // TODO: 處理異常 } });
最后,一定要記得在生命周期結束的地方取消訂閱事件,防止RxJava可能會引起的內存泄漏問題。
@Override protected void onDestroy() { super.onDestroy(); if(!rxSubscription.isUnsubscribed()) { rxSubscription.unsubscribe(); } }
這樣,一個簡單的Event Bus就實現了!如果你的項目已經開始使用RxJava,也許可以考慮替換掉EventBus或Otto,減小項目體積。
RxBus、EventBus因為解耦太徹底,濫用的話,項目可維護性會越來越低;一些簡單場景更推薦用回調、Subject來代替事件總線。
感謝各位的閱讀!關于“如何使用RxJava實現事件總線Event Bus”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。