Kotlin-协程-看完这一篇还不懂,我倒立吃X,脑白金泡澡!

var name = “Huanglinqing”
runOnUiThread {
showMessage(name)
Thread{
getMessageFromNetwork1()
runOnUiThread{

}
}.start()
}
}

依次类推,我们可以想到,如果请求很多的话,第一 代码结构会很难看,第二 写着写着就很乱了,那么协程就可以很好的解决这个问题,下面我们来看使用协程的方式 怎么写.

首先,对于一个耗时的操作,我们需要将他切换到后台线程执行,withContext函数可以构建一个协程作用域,他必须在挂起函数或者协程中执行,suspend关键字是kotlin为我们提供的 用于标记挂起函数的关键字。我们修改getMessageFromNetwork方法如下:

/**

  • 从服务器取信息
    */
    private suspend fun getMessageFromNetwork(): String {

var name = “”
withContext(Dispatchers.IO) {
for (i in 0…1000000) {
//这里模拟一个耗时操作
}

name = “Huanglinqing1111”
}

return name
}

在onCreate中协程中直接这样写:

GlobalScope.launch(Dispatchers.Main) {
var name = getMessageFromNetwork()
showMessage(name)
}

运行结果如下所示:

如果我们有多个请求呢,那就再多加几个

GlobalScope.launch(Dispatchers.Main) {
var name = getMessageFromNetwork()
showMessage(name)
var name1 = getMessageFromNetwork()
showMessage(name1)
var name2 = getMessageFromNetwork()
showMessage(name2)
}

这样getMessageFromNetwork在后台执行,showMessage在前台执行,由此看来。

协程比线程的优势在什么地方?

1、协程可以帮我们自动切线程

2、摆脱了链式回调的问题

Retrofit 如何使用协程

从Retrofit2.6.0开始,retrofit就自动支持协程了,这里我们从「聚合数据」上找到一个开放api

我们先来看之前我们怎么使用的,首先在Apiservice中定义一个接口如下:

@GET(“https://wanandroid.com/article/listproject/0/json”)
fun queryData(): Call<BaseReqData>

在activity中添加如下代码:

var retrofit = Retrofit.Builder()
.baseUrl(“http://v.juhe.cn/”)
.addConverterFactory(GsonConverterFactory.create())
.build()

val apiService = retrofit.create(ApiService::class.java)

tvName.setOnClickListener {
apiService.queryData(“top”,“04ea095cbea56775e2d1669713f34cc2”)
.enqueue(object :Callback<BaseReqData>{
override fun onFailure(call: Call<BaseReqData>, t: Throwable) {
tvName.text = t.toString()
Log.d(“网络请求错误”, t.toString())
}

override fun onResponse(
call: Call<BaseReqData>,
response: Response<BaseReqData>
) {
tvName.text = response.code().toString()
}
})
}

这里我们将返回结果的状态码显示在view上,运行结果如图所示:

上面代码看起来没有什么问题,如果我们用到了mvp模式什么的,便于职责单一,还要单独放一个类中,这样就需要添加回调才能获取返回结果。

那么协程中怎么使用呢?

首先我们在ApiService中新增一个函数 ,声明为挂起函数,类型不需要添加Call

@GET(“toutiao/index”)
suspend fun queryDataKotlin(@Query(“type”) type: String?, @Query(“key”) key: String?): BaseReqData

在onCreate中代码如下所示:

GlobalScope.launch(Dispatchers.Main) {
try {
var result = apiService.queryDataKotlin(“top”, “04ea095cbea56775e2d1669713f34cc2”)
tvName.text = result.toString()
}catch (e:Exception){
tvName.text = e.toString()
}
}

没错就是这么简单,没有什么回调,因为queryDataKotlin是一个挂起函数,当运行到挂起函数的时候,协程会处于等待状态,等返回结果后,主动切回主线程,执行下面的方法。

而try catch的作用,就等同于上面onFailure的回调,这个时候你可能会说了,我去!还要写try catch ,好low的感觉,别忘了,协程的另一个优势就是可以减少回调,如果仍然有成功方法或者失败方法 那还是走了回调的逻辑!

协程提升效率

协程可以提升什么效率,假设,我们现在有两个接口请求,需要等到两个接口都请求完毕的时候  显示出结果,如果在之前会怎么样,先请求接口1 接口1有结果后再请求结果2,而协程可以做到,接口1和接口2同时请求,等请求结束后将结果合并显示过来,这里我们请求统一接口来模拟请求两个不同的接口

GlobalScope.launch(Dispatchers.Main) {
try {
var result1 =
async { apiService.queryDataKotlin(“top”, “04ea095cbea56775e2d1669713f34cc2”) }
var result2 =
async { apiService.queryDataKotlin(“top”, “04ea095cbea56775e2d1669713f34cc2”) }
tvName.text = result1.await().toString() + “\n==\n” + result2.await().toString()+“接口2”
} catch (e: Exception) {
tvName.text = e.toString()
}

}

运行结果如下所示:

这样,本来要分步做的两件事情可以同时做了,当然可以提高效率了,async函数必须在协程作用域中调用,会创建一个新的子协程,并返回一个Deferred对象,调用这个对象的await方法 就可以获取执行结果。

在线上项目中如何使用协程

创建协程的方法有很多,有我们上面说的GlobalScope.launch方法,还有runBlocking方法

GlobalScope.launch 创建的是顶级协程,runBlocking创建的协程在协程作用域的代码没有执行完毕前会一直阻塞线程,所以上面。两个方法都不建议使用。

coroutineScope函数是一个挂起函数,它会继承外部的协程作用域并创建一个子协程,只能在协程作用域或者挂起函数中调用

launch函数必须在协程的作用域中才能调用。

说了这么多 在项目中我们改如何创建协程呢

我们可以直接创建一个CoroutineScope对象,如下所示:

var coroutineScope = CoroutineScope(Dispatchers.Main)

coroutineScope.launch {
}

这样我们就创建了一个协程,可以按照上面的方法使用了

如果在页面打开的时候,我们在协程中进行网络请求,当页面销毁的时候我们也要将协程任务取消以免造成不必要的问题

如何取消协程任务

coroutineScope 直接调用cancle方法即可,如果我们使用的是GlobalScope.launch方法 ,它会返回一个job对象 我们使用job.cancle即可取消协程任务。

最后的最后,协程的强大远远不止上述

在项目中使用Jetpack 对kotlin的扩展,可以更加便捷的创建和使用协程.

如下:

lifecycleScope.launch {
}

viewModelScope.launch {
}

可那又是另外一个故事了~


更新

Kotlin从零到整体系化学习

为什么要学Kotlin?未来大趋势?还是真香呢?

我个人认为:在不牺牲性能或安全性的前提下,许多的Kotlin功能使代码比Java更加简洁易懂。
Kotlin编译为字节码,因此其性能与Java一样好。它具有与Java相同的编译时检查(还有更多内容,例如内置的可空性检查)。最重要的是,Kotlin的语言功能和标准库功能可实现简洁有效的代码。

简洁,因为这是提高程序员工作效率的关键因素。

最初是组装。每行代码仅给您提供整个程序的功能说明。这使得读取和写入都变得困难,因为你必须一次将如此多的代码保存在脑海中。

高级语言使我们可以在每一行代码中添加更多想法。例如,对列表进行排序在大多数现代语言中都是微不足道的。当每行代码获得更多功能时,编写较大的程序会更容易。

但是,我们不想在每行代码中尽可能多地包含想法。如果代码过于简洁,那么它也将变得难以理解。正则表达式就是这个问题的典型例子。简而言之,我仍然会定期与之抗争。

综上,秉持着对Kotlin的热爱,也希望更多的朋友更好的、无痛的上手Kotlin,特将收录整理的《Kotlin从零到整学习笔记》图片中压缩包是大量的Kotlin实战案例,免费分享给大家。大家也可以在我的主页,找到我在B站的Android高阶教学视频更新地址


需要的朋友可以在评论区留下您的邮箱地址,我定期会抽空看评论,然后发给大家。如回复不及时,大家也可以在我的主页介绍处加上我的微信,备注【KT】无偿分享

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

文末

今天关于面试的分享就到这里,还是那句话,有些东西你不仅要懂,而且要能够很好地表达出来,能够让面试官认可你的理解,例如Handler机制,这个是面试必问之题。有些晦涩的点,或许它只活在面试当中,实际工作当中你压根不会用到它,但是你要知道它是什么东西。

最后在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

【Android核心高级技术PDF文档,BAT大厂面试真题解析】

【算法合集】

【延伸Android必备知识点】

【Android部分高级架构视频学习资源】

**Android精讲视频领取学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 13
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值