Android 之 RxJava2

​1.依赖配置​ ​(build.gradle

需添加以下依赖(确保版本兼容):

Groovy 复制代码
implementation 'io.reactivex.rxjava2:rxjava:2.2.20'
implementation 'io.reactivex.rxjava2:rxandroid:2.1.1'
2.​​线程调度​
  • subscribeOn(Schedulers.io()):指定网络请求在IO线程(非主线程)执行,避免阻塞UI。
  • observeOn(AndroidSchedulers.mainThread()):将结果切换到主线程更新UI,否则会崩溃。
​3.操作符使用​
  • map():转换数据格式(如JSON解析),链式调用保持代码简。
  • 其他常用操作符:
    • flatMap():异步嵌套请求(如先登录后获取用户信息)。
    • filter():过滤无效数据。
    • zip():合并多个请求结果
4.示例场景:模拟网络请求获取数据,处理结果后更新 UI
java 复制代码
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
import io.reactivex.Observable;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.CompositeDisposable;
import io.reactivex.disposables.Disposable;
import io.reactivex.schedulers.Schedulers;

public class MainActivity extends AppCompatActivity {
    private TextView tvResult;
    private CompositeDisposable compositeDisposable = new CompositeDisposable();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tvResult = findViewById(R.id.tv_result);

        // 1. 创建 Observable(模拟网络请求)
        Observable<String> observable = Observable.create(emitter -> {
            try {
                Log.d("RxJava", "网络请求线程: " + Thread.currentThread().getName());
                Thread.sleep(2000); // 模拟网络延迟
                String data = "{\"name\":\"RxJava\", \"version\":2}"; // 模拟返回的JSON数据
                emitter.onNext(data); // 发送成功数据
                emitter.onComplete();
            } catch (Exception e) {
                emitter.onError(e); // 发送错误
            }
        });

        // 2. 订阅并处理结果
        Disposable disposable = observable
                .subscribeOn(Schedulers.io()) // 指定网络请求在IO线程执行
                .observeOn(AndroidSchedulers.mainThread()) // 指定结果处理在主线程
                .map(json -> { // 使用map操作符转换数据
                    // 模拟JSON解析(实际可用Gson等库)
                    return "解析结果: " + json.replace("\"", "");
                })
                .subscribe(
                        result -> tvResult.setText(result), // onNext: 更新UI
                        error -> Toast.makeText(this, "请求失败: " + error.getMessage(), Toast.LENGTH_SHORT).show(), // onError
                        () -> Log.d("RxJava", "请求完成") // onComplete
                );

        compositeDisposable.add(disposable); // 统一管理订阅
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        compositeDisposable.clear(); // 防止内存泄漏
    }
}
相关推荐
问心无愧051323 分钟前
ctf show web入门109
android·前端·笔记
xinhuanjieyi42 分钟前
Android 画板应用kotlin实现
android·开发语言·kotlin
故渊at1 小时前
第四板块:Android 输入系统与触控事件 | 第十六篇:按键分发与软键盘(IME)的窗口协同
android·软键盘·输入系统·触控事件·按键分发
故渊at1 小时前
第三板块:Android 图形渲染与窗口体系 | 第十四篇:View 绘制体系与 RenderThread 异步渲染
android·图形渲染·ui线程·renderthread·view体系
Coffeeee1 小时前
准备升级到Android16,自适应布局应该如何适配
android·google·kotlin
神仙别闹1 小时前
基于 PHP + MySQL 图书库存管理系统
android·mysql·php
zhangphil1 小时前
Android内存回收:GC、kswapd 和 mm_vmscan_direct_reclaim概述
android
plainGeekDev1 小时前
ContentProvider → Room + Repository
android·java·kotlin
plainGeekDev2 小时前
SQLite 手动升级 → Room Migration
android·java·kotlin