每个程序员都有一个梦想,那就是进一线互联网公司深造,不要跟我说你不想进去,如果给你一个这样的平台,不管是薪资待遇还是接触的高度来说,对我们程序员来说都是一个机会,我以前有一个同事,就是从阿里出来的,原来是p7,后面来了我们这里当了技术总监,人家的代码写的让你不得不服。
今天我特意收集了最新面试题,虽然花了一些时间,经过整理之后分享给大家,大家一起来看看什么互联网面试题,一起来认识一下,看看自己能掌握多少!
1、MVVM架构模式概览这是使用MVVM架构模式+Kotlin协程+JetPack(viewmodel+liveData)+Retrofit的架构,实现WanAndroID登录接口的小DEMO,后续会慢慢完善WanAndroID客户端
1、viewmodel
为了从界面控制器Activity/Fragment逻辑中分离出视图VIEw数据所有权,架构组件为界面控制器提供了 viewmodel 辅助程序类,该类负责为界面准备数据。在配置更改期间会自动保留 viewmodel 对象,以便它们存储的数据立即可供下一个 Activity 或 Fragment 实例使用。
2、liveData
liveData 是一种可观察的数据存储器类,具有生命周期感知能力,意指它遵循其他应用组件如 Activity、Fragment 或 Service 生命周期,可确保 liveData 仅更新处于活跃生命周期状态的应用组件观察者。liveData 对象通常存储在 viewmodel 对象中,并可通过 getter 方法进行访问。
3、Kotlin协程
协程依附在线程上,可以实现顺序编写异步代码,自动进行线程切换。并且viewmodelScope为应用中的每个 viewmodel 定义了 viewmodelScope。如果 viewmodel 已清除,则在此范围内启动的协程都会自动取消。
4、Retrofit
将服务接口中的网络请求函数声明为suspend挂起接口函数,以支持Kotlin线程,并将suspend函数结果作为 liveData 对象传送。
2、viewmodel//获取viewmodelviewmodel = viewmodelProvIDer(this).get(Mainviewmodel::class.java)`
viewmodel 对象存在的时间范围是获取 viewmodel 时传递给 viewmodelProvIDer 的 lifecycle。viewmodel 将一直留在内存中,直到限定其存在时间范围的 lifecycle 永久消失:对于 Activity,是在 Activity 完成时;而对于 Fragment,是在 Fragment 分离时。
3、liveData//对User数据进行观察viewmodel.user.observe(this, Observer { //展示登录结果 if (it.errorCode == 0) { Toast.makeText(this, it.data?.nickname, Toast.LENGTH_SHORT).show() } else { Toast.makeText(this, it.errorMsg, Toast.LENGTH_SHORT).show() }})
使用 liveData 具有以下优势:确保界面符合数据状态
liveData 遵循观察者模式。当生命周期状态发生变化时,liveData 会通知 Observer 对象。您可以整合代码以在这些 Observer 对象中更新界面。观察者可以在每次发生更改时更新界面,而不是在每次应用数据发生更改时更新界面。
不会发生内存泄漏
观察者会绑定到 lifecycle 对象,并在其关联的生命周期遭到销毁后进行自我清理。
不会因 Activity 停止而导致崩溃
如果观察者的生命周期处于非活跃状态(如返回栈中的 Activity),则它不会接收任何 liveData 事件。不再需要手动处理生命周期界面组件只是观察相关数据,不会停止或恢复观察。liveData 将自动管理所有这些 *** 作,因为它在观察时可以感知相关的生命周期状态变化。
数据始终保持最新状态
如果生命周期变为非活跃状态,它会在再次变为活跃状态时接收最新的数据。例如,曾经在后台的 Activity 会在返回前台后立即接收最新的数据。
适当的配置更改
如果由于配置更改(如设备旋转)而重新创建了 Activity 或 Fragment,它会立即接收最新的可用数据。
共享资源
可以使用单一实例模式扩展 liveData 对象以封装系统服务,以便在应用中共享它们。
4、Kotlin协程4.1、异步的本质什么是异步?
异步就是同时进行一个以上彼此目的不同的任务。
但是对于有前后依赖关系的任务,异步该如何处理呢?
利用异步中的回调机制处理。
为什么需要异步回调机制?
因为不同的任务之间存在前后的依赖关系。
异步回调机制有什么缺点?
代码结构过分耦合,遇到多重函数回调的嵌套耦合,也就是回调地狱,代码会难以维护。
解决回调地狱的方案有什么?
链式调用结构。常见方式就是使用RxJava,它是反应函数式编程在Java中的实现。但是RxJava中流的创建、转化与消费都需要使用到各种类和丰富的 *** 作符,加大了RxJava的学习成本。减少在无封装情况下使用RxJava,因为你无法保证团队里面的每一个成员都能看懂它,并且在修改时都能做出正确选择。
在串行的执行中,虽然代码确实是顺序执行的,但其实是在不同的线程上顺序执行的。那为什么在串行的执行中代码执行顺序一致,却还要使用回调呢?
因为串行的执行中,执行是阻塞式的,主线程的阻塞会导致很严重的问题,所以所有的耗时 *** 作不能在主线程中执行,所以就需要多线程并行来执行。
在并行的执行中,异步回调其实就是代码的多线程顺序执行。那能不能既按照顺序的方式编写代码,又可以让代码在不同的线程顺序执行,自动完成线程的切换工作呢?
那就是Kotlin协程。Kotlin 的协程是一种无栈协程的实现,它的控制流转依靠对协程体本身编译生成的状态机的状态流转来实现,变量保存也是通过闭包语法来实现的。
结论:
异步回调就是代码的多线程顺序执行,而Kotlin协程可以实现顺序编写异步代码,自动进行线程切换。
那么协程自动进行线程切换的原理是什么?
YIEld:让出cpu,放弃调度控制权,回到上一次Resume的地方Resume:获取调度控制权,继续执行程序,到上一次YIEld的地方
例子:
1. GlobalScope.launch发起了一个协程,并在IO线程上执行,2\. 在协程里,去调用接口获取结果。3. 拿到结果,使用withContext(dispatchers.Main)切换到主线程并更新界面
4.2、协程的类型是协程范围,指的是协程内的代码运行的时间周期范围,如果超出了指定的协程范围,协程会被取消执行。
GlobalScope
指的是与应用进程相同的协程范围,也就是在进程没有结束之前协程内的代码都可以运行。
JetPack中提供的生命周期感知型协程范围:
viewmodelScope,为应用中的每个 viewmodel 定义了 viewmodelScope。如果 viewmodel 已清除,则在此范围内启动的协程都会自动取消。lifecycleScope,为每个 lifecycle 对象定义了 lifecycleScope。在此范围内启动的协程会在 lifecycle 被销毁时取消。使用 liveData 时,可能需要异步计算值。可以使用 liveData 构建器函数调用 suspend 函数,并将结果作为 liveData 对象传送。
相关链接:https://developer.androID.@R_419_5561@.cn/topic/librarIEs/architecture/coroutines
4.3、协程的启动launch方法:
/** * 重要知识:viewmodel+协程 */fun viewmodel.launch( block: suspend Coroutinescope.() -> Unit, onError: (e: Throwable) -> Unit = {}, onComplete: () -> Unit = {}) { viewmodelScope.launch(CoroutineExceptionHandler { _, e -> onError(e) }) { try { block.invoke(this) } finally { onComplete() } }}
源码:
public fun Coroutinescope.launch( context: CoroutineContext = EmptyCoroutineContext, start: Coroutinestart = Coroutinestart.DEFAulT, block: suspend Coroutinescope.() -> Unit): Job { val newContext = newCoroutineContext(context) val coroutine = if (start.isLazy) LazyStandaloneCoroutine(newContext, block) else StandaloneCoroutine(newContext, active = true) coroutine.start(start, coroutine, block) return coroutine}
4.3.1、launch方法解释context
协程上下文,可以指定协程运行的线程。默认与指定的Coroutinescope中的coroutineContext保持一致,比如GlobalScope默认运行在一个后台工作线程内。也可以通过显示指定参数来更改协程运行的线程,dispatchers提供了几个值可以指定:dispatchers.Default、dispatchers.Main、dispatchers.IO、dispatchers.Unconfined。
start
协程的启动模式。默认的Coroutinestart.DEFAulT是指协程立即执行,除此之外还有Coroutinestart.LAZY、Coroutinestart.ATOMIC、Coroutinestart.UNdisPATCHED。
block
协程主体。也就是要在协程内部运行的代码,可以通过lamda表达式的方式方便的编写协程内运行的代码。
CoroutineExceptionHandler
指定CoroutineExceptionHandler来处理协程内部的异常。
Job
返回值,对当前创建的协程的引用。可以通过Job的start、cancel、join等方法来控制协程的启动和取消。
4.4、suspend挂起函数suspend关键字只起到了标志这个函数是一个耗时 *** 作,必须放在协程中执行的作用,而withContext方法则进行了线程的切换工作。
协程中的代码自动地切换到其他线程之后又自动地切换回了主线程!顺序编写保证了逻辑上的直观性,协程的自动线程切换又保证了代码的非阻塞性。挂起函数必须在协程或者其他挂起函数中被调用,也就是挂起函数必须直接或者间接地在协程中执行。
那为什么协程中的代码没有在主线程中执行呢?而且执行完毕为什么还会自动地切回主线程呢?
协程的挂起可以理解为协程中的代码离开协程所在线程的过程,协程的恢复可以理解为协程中的代码重新进入协程所在线程的过程。协程就是通过的这个挂起恢复机制进行线程的切换。
4.5、async await方法用async方法包裹了suspend方法来执行并发请求,并发结果都返回之后,切换到主线程,接着再用await方法来获取并发请求结果。
5、Retrofithttp接口suspend挂起函数:
interface APIService { @FormUrlEncoded @POST("user/login") suspend fun loginForm(@FIEld("username") username: String,@FIEld("password") password: String): BaseResponse<User>}
kotlin泛型:
data class BaseResponse<T>( val errorCode: Int=0, val errorMsg:String? = null, var data: T? = null)
这是使用MVVM架构模式+Kotlin协程+JetPack(viewmodel+liveData)+Retrofit的架构,实现WanAndroID登录接口的小DEMO,后续会慢慢完善WanAndroID客户端
文末对于很多初中级AndroID工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对AndroID开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品AndroID架构师教程,保证你学了以后保证薪资上升一个台阶。
当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。
以上进阶BATJ大厂学习资料可以免费分享给大家,需要完整版的朋友,点这里可以看到全部内容。
进阶学习视频
附上:我们之前因为秋招收集的二十套一二线互联网公司AndroID面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理AndroID复习笔记(包含AndroID基础知识点、AndroID扩展知识点、AndroID源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
的朋友,点这里可以看到全部内容。**
进阶学习视频
[外链图片转存中…(img-bTS6jgCs-1623127804752)]
附上:我们之前因为秋招收集的二十套一二线互联网公司AndroID面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理AndroID复习笔记(包含AndroID基础知识点、AndroID扩展知识点、AndroID源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
[外链图片转存中…(img-m08N0Oj2-1623127804754)]
总结以上是内存溢出为你收集整理的渣本毕业两年经验,安卓系列学习进阶视频全部内容,希望文章能够帮你解决渣本毕业两年经验,安卓系列学习进阶视频所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)