build.gradle将库更改为
implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:1.1.1'.
删除,如果添加:
kotlin {
experimental {
coroutines "enable"
}
}
在代码中更改launch为GlobalScope.launch(Dispatchers.IO)or GlobalScope.launch(Dispatchers.Main)。
更新
请使用本地协程上下文而不是全局范围(例如,参见http://kotlinlang.org/docs/reference/coroutines/coroutine-context-and-dispatchers.html)。
对于活动
请参阅https://github.com/Kotlin/kotlinx.coroutines/blob/master/ui/coroutines-guide-ui.md。
实施CoroutineScope:
class YourActivity : AppCompatActivity(), CoroutineScope {
添加一个局部变量job并初始化它:
private lateinit var job: Job
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
job = Job()
}
创建协程上下文并在 Activity 销毁时取消它:
override fun onDestroy() {
job.cancel()
super.onDestroy()
}
override val coroutineContext: CoroutineContext
get() = Dispatchers.Main + job
对于 Fragment(与 中相同Activity)
实现 CoroutineScope:
class YourFragment : Fragment(), CoroutineScope {
创建一个局部变量job并在onCreate(). (我试着写private val job: Job = Job(),但遇到了一个问题,ViewPager你会创建Fragments 和他们的工作。因为我们会在刷入的过程中取消job,onDestroy()所以ViewPager我们应该重新创建工作)。
private lateinit var job: Job
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
job = Job()
}
创建协程上下文并在 Fragment 销毁时将其取消:
override val coroutineContext: CoroutineContext
get() = Dispatchers.Main + job // You can use different variants here.
override fun onDestroy() {
job.cancel()
super.onDestroy()
}
启动示例
launch照常使用:
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
launch {
// Wait for result of I/O operation without blocking the main thread.
withContext(Dispatchers.IO) {
interactor.getCountry().let {
countryName = it.name
}
}
// Update views in the UI thread.
country.updateCaption(countryName)
}
}
在我的情况下,当我使用带有通常回调的 API 请求时出现问题。launch尚未调用回调内部的内部。所以我用交互器重写了那个代码。