我們為什麼要在Android中使用RxJava

來源:互聯網
上載者:User

標籤:round   lambda運算式   組合   mda   override   this   amp   開發人員   obj   

本文翻譯來自–>Why should we use RxJava on Android
另外: 微涼一季
再另外: 微涼一季

感覺RxJava近期風生水起,不學習一下都不好意思了。洒家也是初學RxJava,也是感覺代碼好像更複雜更難懂了。看了一篇外文感同身受,簡單翻譯一下。本文簡介使用RxJava優勢所在。但可能須要有一點RxJava基礎,推薦先看一下拋物線的那篇經典的匠心寫作。
—–華麗切割線。譯文開始———

Reactive Extensions (Rx) 是一系列介面和方法。為開發人員提供了一種易懂且迅速簡單易維護的方法。

RxJava就是幹這事兒的,提供一系列tools來幫你寫出簡潔的代碼。
老實說,一開始我覺得RxJava 寫的代碼理解起來非常困難。而且引入一個庫,單單就是為了用用這樣的新式的api,這困擾到了我。後來。我懂了。以傳統的編碼方式。隨著app的發展,我須要重構代碼、一遍一遍的反覆樣板代碼。以滿足使用者不斷變更的新需求,這讓我苦不堪言。
我做的大量工作,事實上是改寫相關方法和介面,就是由於需求的變更(這是開發與產品間那些血案的原罪)或者須要改變展示的資訊亦或是須要改變處理資訊資料..這非常抓狂。

另外。這樣的代碼讓其它來維護的人來理解,一般是非常耗時的。


舉個栗子:我們須要從資料庫擷取一組使用者的鏈表資料,並展示出來。我們能夠用AsyncTask後台查詢資料庫,獲得的結果給Ui的適配器展示出來。簡單示範範例代碼:

public class SampleTask extends AsyncTask<Void,Void,List<Users>> {    private final SampleAdapter mAdapter;    public SampleTask(SampleAdapter sampleAdapter) {        mAdapter = sampleAdapater;    }    @Override    protected List<Users> doInBackground(Void... voids) {        //fetch there results from the database and return them to the onPostExecute        List<Users> users = getUsersFromDatabase();        return users;    }    @Override    protected void onPostExecute(List<Users> users) {        super.onPostExecute(products);        // Checking if there are users on the database        if(users == null) {            //No users, presenting a view saying there are no users            showEmptyUsersMessageView();            return;        }        for(User user : users){            mAdapter.add(user);        }        mAdapter.notifyDataSetChanged();    }}

如今有個新需求,要求僅僅顯示非guest的user,我們處理的方法是,在加入到adapter前加個條件推斷是不是guset,或者改變資料庫查詢的條件。

更有甚者。你又被要求從資料庫中擷取另外的其它資訊。跟user一併在這個adapter中顯示出來呢?
這就是我們為什麼要用RxJava了,把我們從這個泥潭中拉出來。換個姿勢。我們Rx代碼是這樣子(如果您已學習過Rx基礎使用方法):

public Observable<List<User>> fetchUsersFromDatabase() {    return Observable.create(new Observable.OnSubscribe<List<User>(){        @Override        public void call(Subscriber<?

super List<User>> subscriber){ // Fetch information from database subscriber.onNext(getUserList()); subscriber.onCompleted(); } });}

像這樣被調用:

fetchUsersFromDatabase().subscribeOn(Schedulers.io())//will process everything in a new thread.observeOn(AndroidSchedulers.mainThread())//will listen the results on the main thread.subscribe(new Subscriber<List<User>>() {           @Override            public void onCompleted() {            }            @Override            public void onError(Throwable e) {            }            @Override            public void onNext(List<User> users) {                //Do whatever you want with each user            }        });

開始改需求了哈
怎麼不顯示guests呢。RxJava分分鐘過濾掉這樣的不速之客:

fetchUsersFromDatabase()        .filter(new Func1<User, Boolean>() {            @Override            public Boolean call(User user) {                //only return the users which are not guests                return !user.isGuest();            }        })        .subscribeOn(Schedulers.io())        .observeOn(AndroidSchedulers.mainThread())        .subscribe(new Subscriber<User>() {                       @Override                       public void onCompleted() {                       }                       @Override                       public void onError(Throwable e) {                           /*Check if there was any error while retrieving from database*/                       }                       @Override                       public void onNext(User user) {                           //Do whatever you want with each user                       }                   }        );

傳統的方式,即便是個簡單的變更。為了保持優雅的介面化編程,我們也得建立新介面,重構代碼來實現過濾。

可是使用RxJava讓這一切變得優雅了,我們僅僅須要一個被觀察者用來擷取全部的資訊,讓後你就能夠盡情的用這些方法來過濾擷取你想要的資料。
可能你又會說了。ok,這是非常好非常易讀的結構。可是這似乎使代碼量變多了呢。well you are right,可是這就是Retrolambda閃耀的時候了,這個庫為我們相容了以使用java8 lambda運算式,方法引用等等。


幫我們簡化代碼例如以下:

fetchUsersFromDatabase()        .subscribeOn(Schedulers.io())        .observeOn(AndroidSchedulers.mainThread())        .subscribe(value -> {                    //Do whatever with the value                },error -> {                    //do something with in case of error                }        );

這個問題完美搞定,然後你又開始問了,我須要添加另外的查詢結果和user一同顯示在這個adapter中怎麼破。這真不是事兒:

fetchUsersFromDatabase()        .zipWith(fetchSomethingElseFromDatabase(), (users, somethingElse) -> {            /*here combine users and something else into a new object*/        })        .subscribe( o -> {            /*use the combine object from users and something else to fill the adapter */});

如上,我們能夠輕鬆組合資料庫查出來的其它資料和users給一個adapter一同顯示。是不是更易維護。代碼少。易讀,清晰?
如果要更深入的學習RXJava能夠看以下這篇文章,我看後受益匪淺。


[Party tricks with RxJava, RxAndroid & Retrolambda](https://medium.com/p/1b06ed7cd29c)
另外,這篇教程 [tutorial ](https://gist.github.com/staltz/868e7e9bc2a7b8c1f754) 也幫我在RxJava路上進階了非常多。

我們為什麼要在Android中使用RxJava

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.