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);
}
});