前言
《第一行代码》第三版相信很多人都去进行了阅读,像我这样的小白也借此机会学习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也比较方便。书中有很多更好的方式来展现这一套一套的,但可能硬插入项目中是不行的,不知道此处提供的方式是否是大家经常使用的。