優雅的解決Retrofit RxAndroid關聯生命週期問題

RAE發表於2019-05-14

Retrofit結合RxAndroid應該是史上最好用的網路請求框架了,在專案中只需要一段程式碼就可以完成網路請求以及回撥處理,來看看google官方示例

public class UserActivity extends AppCompatActivity {
    // 資料提供
    private UserViewModel mViewModel;
    // 管理subscriptions訂閱的釋放
    private final CompositeDisposable mDisposable = new CompositeDisposable();

    @Override
    protected void onStart() {
        super.onStart();
        // 發起網路請求
        mDisposable.add(mViewModel.getUserName()
                .subscribeOn(Schedulers.io()) // 請求在IO執行緒執行
                .observeOn(AndroidSchedulers.mainThread()) // 回撥到Android主執行緒
                .subscribe(userName -> mUserName.setText(userName), // 回撥監聽
                        throwable -> Log.e(TAG, "Unable to update username", throwable)));
    }

    @Override
    protected void onStop() {
        super.onStop();
        // 釋放請求
        mDisposable.clear();
    }
}
複製程式碼

在上面的例子中,所有的請求都必須要addCompositeDisposable中,在Activity停止的時候進行釋放操作。如果不釋放的話會怎麼樣?答案是程式會崩潰。因為你的網路請求是執行在非同步執行緒IO中去的,當執行緒完成後回撥到主執行緒來,發現Activity跑路(被釋放)了,回撥的subscribe(...)找不到物件了,那肯定不幹啊,執行緒也是有點小脾氣的嘛。

痛點

程式設計師都是"很懶的",一來寫程式碼不好看,每個請求要巢狀在add()括號中;二來要在Activity銷燬的時候進行釋放。

Retrofit Rxandroid Adapter

為解決Retrofit關聯的ActivityFragment生命週期而設計。

一、用法

通過with(this)來關聯生命週期,簡化Activity.onStop()的釋放操作。

public class UserActivity extends AppCompatActivity {
	@Override
	protected void onCreate(@Nullable Bundle savedInstanceState) {
		MyService service = retrofit.create(MyService.class); // 你的介面
		service.getUser()
		       .with(this) // 關聯生命週期
		       .subscribe(new YourObserver());
	}
}
複製程式碼

二、配置

1、在Retrofit初始化的例項的時候,新增RxAndroidCallAdapterFactory 作為回撥介面卡。

Retrofit retrofit = new Retrofit.Builder()
    .baseUrl("https://example.com/")
    // 新增介面卡
    .addCallAdapterFactory(RxAndroidCallAdapterFactory.create())
    .build();
複製程式碼

2、改寫你的介面返回值,由之前的Observable<>改為AndroidObservable<>

interface MyService {
  @GET("/user")
  AndroidObservable<User> getUser();
}
複製程式碼

三、下載

allprojects {
	repositories {
		// ... 省略其他
		maven { url 'https://jitpack.io' }
	}
}
複製程式碼
dependencies {
	implementation 'com.github.raedev:retrofit-rxandroid-adapter:latest.version'
}
複製程式碼

AndroidObservable

原始碼請檢視 開源地址:https://github.com/raedev/retrofit-rxandroid-adapter

相關文章