Android Kotlin协程和Retrofit结合使用

转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/118085035
本文出自【赵彦军的博客】

往期精彩文章:
Kotlin实战指南二十:flow
Kotlin实战指南十六:Synchronized、Volatile
Android Coroutines Channels
Android Flow遇见Retrofit网络请求实践
Android Kotlin协程和Retrofit结合使用
Retrofit 注解参数详解

先定义实体类

class Repo(val id: String, val name: String)

Retrofit 正常使用

定义接口 GitHubService

interface GitHubService {

    @GET("users/{user}/repos")
    fun listRepos(@Path("user") user: String?): Call<List<Repo>>
}

使用

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val retrofit = Retrofit.Builder()
            .baseUrl("https://api.github.com/")
            .addConverterFactory(GsonConverterFactory.create())
            .build()
        val service: GitHubService = retrofit.create(GitHubService::class.java)

        val call = service.listRepos("zyj1609wz")
        call.enqueue(object : Callback<List<Repo>> {

            override fun onResponse(call: Call<List<Repo>>, response: Response<List<Repo>>) {
                val list = response.body()
                tv.text = "ok ${list?.get(0)?.name}"
            }

            override fun onFailure(call: Call<List<Repo>>, t: Throwable) {
                tv.text = "fail ${t.message}"
            }

        })
    }
}

Retrofit结合协程方式一

下面我们来使用协程请求网络接口

定义接口 GitHubService

interface GitHubService {

    @GET("users/{user}/repos")
    fun listRepos(@Path("user") user: String?): Call<List<Repo>>
}

在协程里面请求网络

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val retrofit = Retrofit.Builder()
            .baseUrl("https://api.github.com/")
            .addConverterFactory(GsonConverterFactory.create())
            .build()
        val service: GitHubService = retrofit.create(GitHubService::class.java)

        GlobalScope.launch {
            try {
                val call = service.listRepos("zyj1609wz")
                val response = call.execute()
                val list = response.body()
                tv.text = "ok ${list?.get(0)?.name}"
            } catch (e: Exception) {
                tv.text = "fail ${e.message}"
            }
        }
    }
}

这样我们就完成了, 协程和retrofit 结合,这只是一个简单的运用,仅仅把协程当做线程来使用。

Retrofit结合协程方式二

GitHubService 函数改为挂起函数,并且把返回值从 Call 改为List

interface GitHubService {

    @GET("users/{user}/repos")
    suspend fun listRepos(@Path("user") user: String?): List<Repo>
}

使用

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val retrofit = Retrofit.Builder()
            .baseUrl("https://api.github.com/")
            .addConverterFactory(GsonConverterFactory.create())
            .build()
        val service: GitHubService = retrofit.create(GitHubService::class.java)

        GlobalScope.launch(Dispatchers.Main) {
            try {
                //这是一个挂起函数
                val list = service.listRepos("zyj1609wz")
                tv.text = "ok ${list?.get(0)?.name}"
            } catch (e: Exception) {
                tv.text = "fail ${e.message}"
            }
        }
    }

}

Retrofit结合协程方式三

async 模拟两个并行任务

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val retrofit = Retrofit.Builder()
            .baseUrl("https://api.github.com/")
            .addConverterFactory(GsonConverterFactory.create())
            .build()
        val service: GitHubService = retrofit.create(GitHubService::class.java)

        GlobalScope.launch(Dispatchers.Main) {
            try {
                val list = async { service.listRepos("zyj1609wz") }
                val list2 = async { service.listRepos("zyj1609wz") }

                //两个请求是并行的
                val result1 = list.await()
                val result2 = list2.await()

                tv.text = "ok ${result1[0].name} ${result2[0].name}"
            } catch (e: Exception) {

            }
        }
    }
}
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值