RxJava與RxAndroid學習記錄

Rxjava與RxAndroid學習記錄之操作符

  • 過濾重複數據
  • 過濾連續的重複數據
  • 轉換(String – int)
  • 通過Filter操作符過濾數據
  • 通過take操作符指定數量
  • 使用Okhttp與Rxjava請求網絡

  • 過濾重複數據
List<String> list = new ArrayList<>();
        list.add("111");
        list.add("111");
        list.add("12");
        list.add("23");
        list.add("11");
        list.add("23");
        Observable<String> distinct = Observable.from(list).distinct();
        distinct.subscribe(new Subscriber<String>() {
            @Override
            public void onCompleted() {
                Log.e(TAG, "onCompleted");
            }

            @Override
            public void onError(Throwable e) {

            }

            @Override
            public void onNext(String s) {
                Log.e(TAG, s);
            }
        });

上述代碼執行後輸出爲:可以看到重複的數據已經被過濾掉了,當onNext()執行完後會調用onCompleted方法
這裏寫圖片描述

  • 過濾連續的重複數據
    使用distinctUntilChanged操作符即可
List<String> list = new ArrayList<>();
        list.add("111");
        list.add("111");
        list.add("12");
        list.add("23");
        list.add("111");
        list.add("23");
        Observable<String> distinct = Observable.from(list).distinctUntilChanged();
        distinct.subscribe(new Subscriber<String>() {
            @Override
            public void onCompleted() {
                Log.e(TAG, "onCompleted");
            }

            @Override
            public void onError(Throwable e) {

            }

            @Override
            public void onNext(String s) {
                Log.e(TAG, s);
            }
        });

此時輸出結果爲下圖,可見前面兩個連續的111被過濾掉了,後面有個111數據由於不是連續的重複數據,沒有被過濾
這裏寫圖片描述

  • 轉換(ps:目前學習不深入,還不知道具體作用)
        String str = "hello world";
        Subscription subscribe = Observable.just(str)
                .map(s -> s.hashCode())
                .subscribe(i -> Log.e(TAG, i +""));

輸出結果爲:1794106052

  • 過濾數據(條件)
        List<String> list = new ArrayList<>();
        list.add("111");
        list.add("111");
        list.add("12");
        list.add("23");
        list.add("1113");
        list.add("23");
        Observable.just(list)
                .flatMap(strings2 -> Observable.from(strings2))
                .filter(strings -> strings.contains("11"))
                .subscribe(strings1 -> Log.e(TAG, strings1));

輸出結果如下:
這裏寫圖片描述

  • 通過take操作符指定數量
        List<String> list = new ArrayList<>();
        list.add("111");
        list.add("111");
        list.add("12");
        list.add("23");
        list.add("1113");
        list.add("23");
        Observable.just(list)
                .flatMap(strings2 -> Observable.from(strings2))
                .filter(strings -> strings.contains("11"))
                .take(1)
                .subscribe(strings1 -> Log.e(TAG, strings1));

輸出結果爲:08-22 04:44:49.838 531-531/? E/MainActivity: 111,由結果可見,本來滿足條件的數據有3條,但是take操作符指定的數量爲1,所以只打印了一條數據

  • 使用Okhttp與Rxjava請求網絡(模擬登錄請求)
    public Observable getRequest(final String url, final Map<String, String> params){
       return Observable.create(new Observable.OnSubscribe<String>() {
           @Override
           public void call(Subscriber<? super String> subscriber) {
               FormBody.Builder builder = new FormBody.Builder();
               for (String key : params.keySet())
                   builder.add(key, params.get(key));
               FormBody build = builder.build();
               Request request = new Request.Builder().url(url).post(build).build();
               OkHttpClient okHttpClient = new OkHttpClient();
               try {
                   Response response = okHttpClient.newCall(request).execute();
                   if (response.code() == 200)
                       subscriber.onNext(response.body().string());
               } catch (IOException e) {
                   subscriber.onError(e);
               } finally {
                   subscriber.onCompleted();
               }
           }
       });
   }
   // 使用
   Map<String, String> params = new HashMap<>();
        //封裝數據
        params.put("loginname", "111");
        params.put("loginpass", "111");
        String url = "**************";
        Observable observable = RxUtils.getRequest(url, params);
        observable.subscribeOn(Schedulers.io())//指定請求數據放在IO線程
            .observeOn(AndroidSchedulers.mainThread())// 指定輸出線程在MainThread(UI線程)
            .subscribe(new Observer<String>() {
            @Override
            public void onCompleted() {
                // 該方法最後被調用
                Log.e(TAG, "onCompleted");
            }

            @Override
            public void onError(Throwable e) {
                // 出現異常時調用
                Log.e(TAG, e.getMessage());
            }

            @Override
            public void onNext(String s) {
                // 獲取數據結果
                Log.e(TAG, s);
            }

        });
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章