implementation ‘com.squareup.retrofit2:adapter-rxjava2:2.8.1’
implementation ‘io.reactivex.rxjava2:rxjava:2.0.1’
implementation ‘io.reactivex.rxjava2:rxandroid:2.0.1’
中级
随着Kotlin的兴起,市面上对网络请求的写法也是大相径庭,网络框架也开始演变出自己的风格,甚至有些公司自己封装网络请求库,没有什么问题啊,反正主要思路就是动态代理。百花齐放的时代来临。
interface AuthService {
@POST(“v5/login”)
fun login(@Body body: RequestBody): Observable<BaseResponse>
}
为了追求更加新颖的写法,将@Field换成了@Body,返回值模型增加了公共的code、msg等。
高级一阶
由于经验逐渐变得丰富,你开始使用Kotlin的协程,因为你对更牛逼技术的追求一直没有停止过。
interface AuthService {
@POST(“v6/login”)
suspend fun login(@Body body: RequestBody): BaseResponse
}
这个时候retrofit的写法就已经进入到了第6代,你问为什么是第6代?这个不是重点,我编的。你直接将API接口中定义的函数变成了suspend函数,方便在协程作用域发起。同时你去掉了Observable这个RxJava的产物,返回值又回到了最初的状态。你不禁感慨,从哪里来,到哪里去。返璞归真了!
高级二阶
你以为到这就结束了?随着Flow的问世,网络请求就进入到了第七世代。Flow是基于协程的产物,可以不用挂起函数了。而且Flow具备RxJava的优良特性,可以对数据流进行变换,也可以监听函数执行的生命周期。这样就方便添加显示加载中对话框和隐藏加载中对话框,以及加载进度了。
interface AuthService {
@POST(“v7/login”)
fun login(@Body body: RequestBody): Flow<BaseResponse>
}
dcache框架如何支持协程和Flow
我的dcache框架1.x的稳定版本,不支持flow。
implementation(“com.github.dora4:dcache-android:1.8.5”)
你需要使用2.0.12及以上版本,对flow请求有很好的支持。
implementation(“com.github.dora4:dcache-android:2.0.12”)
接下来我们简单阅读下DoraHttp.kt的源代码。
/**
- 将一个普通的api接口包装成Flow返回值的接口。
*/
suspend fun flowResult(requestBlock: suspend () -> T,
loadingBlock: ((Boolean) -> Unit)? = null,
errorBlock: ((String) -> Unit)? = null,
) : Flow {
return flow {
// 设置超时时间为10秒
val response = withTimeout(10 * 1000) {
requestBlock()
}
emit(response)
}
.flowOn(Dispatchers.IO)
.onStart {
loadingBlock?.invoke(true)
}
.catch { e ->
errorBlock?.invoke(e.toString())
}
.onCompletion {
loadingBlock?.invoke(false)
}
}
这个函数建议在net作用域内执行,net协程作用域的定义请参见DoraHttp.kt的详细源代码,github.com/dora4/dcach… 。高阶函数的block参数定义中,如果加suspend关键字,则可以传入suspend块,也可以传入普通的方法块。如果不加suspend关键字,则只能传入普通方法块。这个函数对应第6代的写法,可以翻看前面的内容。Flow最终调用collect {} 来处理业务逻辑。
/**
- 直接发起Flow请求,如果你使用框架内部的[dora.http.retrofit.RetrofitManager]的话,需要开启
- [dora.http.retrofit.RetrofitManager]的flow配置选项[dora.http.retrofit.RetrofitManager.Config.useFlow]
- 为true。
*/
suspend fun flowRequest(requestBlock: () -> Flow,
successBlock: ((T) -> Unit),
failureBlock: ((String) -> Unit)? = null,
loadingBlock: ((Boolean) -> Unit)? = null
) {
requestBlock()
.flowOn(Dispatchers.IO)
.onStart {
loadingBlock?.invoke(true)
}
.catch { e ->
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数HarmonyOS鸿蒙开发工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年HarmonyOS鸿蒙开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上HarmonyOS鸿蒙开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注鸿蒙获取)
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
蒙获取)**
[外链图片转存中…(img-NjD2pp9v-1712698648349)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!