《第一行代码》第三版相信很多人都去进行了阅读,像我这样的小白也借此机会学习Kotlin一波,很多东西用起来都觉得“真香”!但是在协程这方面,遇到了一些阻碍,原因是项目中可能已经封装好完整的网络请求框架了,迫于需求,一直没有尝试学习并引进协程,终于在同事的一个需求借机下,使用了协程,主要是觉得如果用协程真的很方便,而且逻辑会很顺畅。下面简单列一下自己在项目中的使用。
先看一下封装的请求,简化请求,走个流程,使用的okhttp。 这里面的需求比较奇葩,用了两个请求,但是结果放在了一个model里面,最后要把完整的model发送出去。
class RequestTest { suspend fun request() : ListModel{ //执行,livemodel等待结果返回,执行下一个方法 val livemodel = getLiveMeetingList() //执行,historymodel等待结果返回 val historymodel = getHistoryMeetingList() livemodel.listHistoryData = hothistorymodel.listHistoryData return livemodel } private suspend fun getLiveMeetingList() : ListModel { return suspendCoroutine { ... client.newCall(request).enqueue(object : Callback { override fun onFailure(p0: Call?, p1: IOException?) { it.resumeWithException(p1) } override fun onResponse(p0: Call, p1: Response) { ... it.resume(listModel) } }) } } private suspend fun getHistoryMeetingList() : ListModel{ return suspendCoroutine { ...如上... } } class ListModel { var listHistoryData var listLiveData } }看起来有点奇葩,但是改代码,总是要适配之前写的,重新推翻的代价总是很大的。 接下里看调用的地方,因为是suspend方法,所以要在协程作用域中执行,两种开启作用域的方法都有它不好的地方,郭神也在书中道出了推荐的做法。
class TestViewModel : ViewModel() { private val _data = MutableLiveData<ListModel>() val data = _data private val requestTest = RequestTest() private val job = Job() private val scope = corouttineScope(job) fun request() { scope.launch { _data.postValue(requestTest.request()) } } override fun onCleared() { super.onCleared() job?.let { it.cancel() } } }协程目前我就使用了这一种方式,最后不需要使用的时候cancel也比较方便。书中有很多更好的方式来展现这一套一套的,但可能硬插入项目中是不行的,不知道此处提供的方式是否是大家经常使用的。