Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/202.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/kotlin/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
与Kotlin Android合作升级_Android_Kotlin_Kotlin Coroutines - Fatal编程技术网

与Kotlin Android合作升级

与Kotlin Android合作升级,android,kotlin,kotlin-coroutines,Android,Kotlin,Kotlin Coroutines,您需要创建一个协程上下文实例,并为其定义一个作业。 val job=job() val coroutineScope=CoroutineContext(Dispatchers.Main+job) 然后使用声明的作用域开始工作,当您想要取消工作时,只需调用job.cancel(),即可取消所有当前和即将进行的工作。Hi,假设我调用了服务器端的url。然后调用cancel。服务器端的工作也会被取消吗?因为这就是我想要的。如果你取消正在进行的请求,服务器将停止发送数据。主要是应该这样。尝试取消改装请

您需要创建一个协程上下文实例,并为其定义一个作业。

val job=job()
val coroutineScope=CoroutineContext(Dispatchers.Main+job)


然后使用声明的作用域开始工作,当您想要取消工作时,只需调用
job.cancel()
,即可取消所有当前和即将进行的工作。

Hi,假设我调用了服务器端的url。然后调用cancel。服务器端的工作也会被取消吗?因为这就是我想要的。如果你取消正在进行的请求,服务器将停止发送数据。主要是应该这样。尝试取消改装请求。
Dispatchers.Main
不在core coroutines库中,但在
kotlinx coroutines android
中。是的,谢谢,我导入了实现“org.jetbrains.kotlinx:kotlinx coroutines android:1.2.0-alpha”使其工作。
class Service{
    interface  RedditApi {
        @GET("/top.json")
        fun getTop(@Query("after") after: String,
                   @Query("limit") limit: String)
                : Deferred<Response<News>>;
    }
}
 val okHttpClient = OkHttpClient.Builder()
            .readTimeout(40, TimeUnit.SECONDS)
            .addInterceptor { chain ->
                val ongoing = chain.request().newBuilder()
                ongoing.addHeader("Cache-Control", "no-cache")
                ongoing.addHeader("User-Agent", System.getProperty("http.agent"))
                //ongoing.addHeader("Authorization", val.trim());
                chain.proceed(ongoing.build())
            }
            .connectTimeout(40, TimeUnit.SECONDS)
            .build()
        val retrofit = Retrofit.Builder()
            .baseUrl( "/rest/s1/mobile/")
            .addConverterFactory(GsonConverterFactory.create())
            .addCallAdapterFactory(CoroutineCallAdapterFactory())
            .client(okHttpClient)
            .build()
        redditApi = retrofit.create(Service.RedditApi::class.java)
class MainActivity : AppCompatActivity(), Fightable {
        override fun onCreate(savedInstanceState: Bundle?) {
            super.onCreate(savedInstanceState)
            setContentView(R.layout.activity_main)


            CoroutineScope(Dispatchers.IO).launch {
                val request = App.redditApi.getTop("after", "limit")
                withContext(Dispatchers.Main) {
                    try {
                        val response = request.await()
                        if (response.isSuccessful) {
                            val news: News? = response.body()
                            //Do something with response e.g show to the UI.
                        } else {
                        }
                    } catch (e: HttpException) {
                    } catch (e: Throwable) {
                    }
                }
            }}}