阅读 3491

Android 中高级面试必知必会

又到年底了,每到这个时候,我们都会慢慢反思,这一年都做了什么?有什么进步?年初的计划都实现了吗?明年年初有跳槽的底气了吗?况且今年的互联网环境太差,需要自己有足够的知识储备,才能够应对这凌冽的寒风。

本文主要是整理了中高级安卓需要会的(或者说面试被频繁问到的内容),主要作为参考大纲,之后会陆续更新每个详细部分,供大家参考,互相学习。

1、Java 相关

  1. 容器(HashMap、HashSet、LinkedList、ArrayList、数组等)

需要了解其实现原理,还要灵活运用,如:自己实现 LinkedList、两个栈实现一个队列,数组实现栈,队列实现栈等。

HashMap、HashTable 和 CurrentHashMap 的核心区别(并发),其次内部数据结构的实现、扩容、存取操作,再深一点 哈希碰撞,哈希计算,哈希映射,为什么是头插法,扩容为什么是 2 的幂次等。

参考链接

JAVA容器-自问自答学HashMap
什么是HashMap?
从源码角度认识ArrayList,LinkedList与HashMap

  1. 内存模型

参考链接

理解Java内存模型
你了解Java内存模型么(Java7、8、9内存模型的区别)

  1. 垃圾回收算法(JVM)
JVM 类加载机制、垃圾回收算法对比、Java 虚拟机结构

当你讲到分代回收算法的时候,不免会被追问到新生对象是怎么从年轻代到老年代的,以及可以作为 root 结点的对象有哪些两个问题。
复制代码

1、谈谈对 JVM 的理解?
2、JVM 内存区域,开线程影响哪块区域内存?
3、对 Dalvik、ART 虚拟机有什么了解?对比?

ART 的机制与 Dalvik 不同。在Dalvik下,应用每次运行的时候,字节码都需要通过即时编译器(just in time ,JIT)转换为机器码,这会拖慢应用的运行效率,而在ART 环境中,应用在第一次安装的时候,字节码就会预先编译成机器码,极大的提高了程序的运行效率,同时减少了手机的耗电量,使其成为真正的本地应用。这个过程叫做预编译(AOT,Ahead-Of-Time)。这样的话,应用的启动(首次)和执行都会变得更加快速。

优点:

  • 系统性能的显著提升。
  • 应用启动更快、运行更快、体验更流畅、触感反馈更及时。
  • 更长的电池续航能力。
  • 支持更低的硬件。

缺点:

  • 机器码占用的存储空间更大,字节码变为机器码之后,可能会增加10%-20%(不过在应用包中,可执行的代码常常只是一部分。比如最新的 Google+ APK 是 28.3 MB,但是代码只有 6.9 MB。)
  • 应用的安装时间会变长。

4、垃圾回收机制和调用 System.gc()的区别?

参考链接

Java虚拟机(JVM)你只要看这一篇就够了!

  1. 类加载过程(需要多看看,重在理解,对于热修复和插件化比较重要)
  2. 反射
  3. 多线程和线程池
线程有哪些状态,哪些锁,各种锁的区别

并发编程:
synchronized 和 volatile 、ReentrantLock 、CAS 的区别

synchronized 修饰实例方法和修饰静态方法有啥不一样。
复制代码

sleep 、wait、yield 的区别,wait 的线程如何唤醒它

  1. HTTP、HTTPS、TCP/IP、Socket通信、三次握手四次挥手过程
计算机网络部分:
1、TCP 有哪些状态
2、三次握手、四次挥手。为啥不是三次不是两次
3、HTTPS 和 HTTP 的区别,HTTPS 2.0 3.0?
4、浏览器输入一个 URL 按下回车网络传输的流程?
5、问的深一点的可能涉及到网络架构,每层有什么协议,FTP 相关原理,例:TCP 建立连接后,发包频率是怎么样的?

复制代码
  1. 设计模式(六大基本原则、项目中常用的设计模式、手写单例等)
1、生产者模式和消费者模式的区别?
2、单例模式双重加锁,为什么这样做?
3、知道的设计模式有哪些?
4、项目中常用的设计模式有哪些?
5、手写生产者、消费者模式。
6、手写观察者模式代码。
7、适配器模式、装饰者模式、外观模式的异同?
8、谈谈对 java 状态机的理解。
9、谈谈应用更新(灰度、强制更新、分区更新?)
复制代码
  1. 断点续传
  2. Java 四大引用
强引用、软引用、弱引用、虚引用的区别以及使用场景。

强引用置为 null,会不会被回收?

稍微问的深一些的面试官会和内存泄漏检测原理以及垃圾回收糅杂在一起。

复制代码
  1. Java 的泛型,<? super T> 和 <? extends T> 的区别
问到泛型、泛型擦除、通配符相关的东西
复制代码
  1. final、finally、finalize 的区别
  2. 接口、抽象类的区别

2、Android 相关

  1. 自定义 View
    1、ViewGroup 绘制顺序 (例:自定义 ViewGroup 如何实现 FlowLayout?如何实现 FlowLayout 调换顺序)
    2、 自定义 View 如何实现打桌球效果;
    3、 自定义 View 如何实现拉弓效果,贝瑟尔曲线原理实现?

(参考链接:自定义View,有这一篇就够了 - 简书Android 自定义 View) 2. 事件拦截分发(Android事件分发机制,大表哥带你慢慢深入 - 简书 )

事件分发已经不是直接让你讲了,会给你具体的场景,比如 A 嵌套 B ,B 嵌套 C,从 C 中心按下,一下滑出到 A,事件分发的过程,这里面肯定会有 ACTION_CANCEL 的相关调用时机。
复制代码
  1. 解决过的一些性能问题,在项目中的实际运用。

  2. 性能优化工具
    (TraceView、Systrace、调试 GPU 过度绘制 & GPU 呈现模式分析、Hierarchy Viewer、MAT、Memory Monitor & Heap Viewer & Allocation Tracker 等)

  3. 性能优化 (讲讲你自己项目中做过的性能优化) (1)网络:API 优化、流量优化、弱网优化
    (2)内存:OOM 处理、内存泄漏、内存检测、分析、Bitmap 优化
    LeakCanary 原理,为什么检测内存泄漏需要两次? (3)绘制
    (4)电量:WeakLock 机制、JobScheduler 机制
    (5)APK 瘦身
    (APK 瘦身是怎么做的,只用 armabi-v7a 没有什么问题么? APK 瘦身这个基本是 100% 被面试问到,可能是我简历上提到的原因。)
    (6)内存抖动
    (7)内存泄漏
    (8)卡顿 {如何检测卡顿,卡顿原理是什么,怎么判断页面响应卡顿还是逻辑处理造成的卡顿}
    BlockCanary 的原理
    (9)性能优化:布局优化、过度渲染处理、ANR 处理、监控、埋点、Crash 上传。
    (10)启动优化

冷启动什么的肯定是基础,后续应该还有的是懒加载,丢线程池同步处理,需要注意这里可能会有的坑是,丢线程池如何知道全部完成。
复制代码

问题
1、启动页白屏及黑屏解决?
2、启动太慢如何解决?
3、启动崩溃捕捉?
4、Https 请求慢的解决办法(DNS、携带数据、直接访问 IP) 5. 缓存自己如何实现(LRUCache 原理) 8. 图形图像相关:OpenGL ES 管线流程、EGL 的认识、Shader 相关 9. SurfaceView、TextureView、GLSurfaceView 区别及使用场景 10. 动画、差值器、估值器Android中的View动画和属性动画 - 简书Android 动画 介绍与使用

属性动画、补间动画、帧动画的区别和使用场景
复制代码
  1. MVC、MVP、MVVM
相互间的区别和各种使用场景,如何选择适合自己的开发架构。
复制代码
  1. Handler、ThreadLocal、AsyncTask、IntentService 原理及应用
Handler 机制原理,IdleHandler 什么时候调用。
复制代码
  1. Gradle(Groovy 语法、Gradle 插件开发基础)

  2. 热修复、插件化
    (1、谈谈对 ClassLoader 的理解
    2、双亲委托机制的好处
    3、自定义 ClassLoader 4、插件化为什么会出现,如何代码加载,资源加载,代理 Hook)

  3. Activity 生命周期

  4. Android 的 4 大启动模式,注意 onNewIntent() 的调用。

  5. 讲讲 Android 的四大组件;

  6. 组件化架构思路
    1、如何从一个老项目一步步实现组件化,主要问思路,考察架构能力和思考能力。(需要考虑很多,每一步做什么,顺序很重要)
    2、组件化和模块化的理解与区别?

  7. 系统打包流程

  8. Android 有哪些存储数据的方式。

  9. SharedPrefrence 源码和问题点;

  10. sqlite 相关
    1、sqlite 升级,增加字段的语句
    2、数据库框架对比和源码分析
    3、数据库优化及数据迁移问题
    4、getWritableDatabase 和 getReadableDatabase 的区别

  11. ListViewRecyclerView 区别?RecyclerView 有几层缓存,如何让两个 RecyclerView 共用一个缓存?
    1、RecycleView 如何进行局部刷新。 2、性能优化。

  12. 如何判断一个 APP 在前台还是后台?

  13. 如何做应用保活?全家桶原理?

  14. 混合开发
    1、 Hybrid 做过吗? :Android 通过WebView调用 JS 代码 :JS 通过WebView调用 Android 代码;
    2、Hybrid 通信原理是什么,有做研究吗?
    3、说说你用过的混合开发技术有哪些?各有什么优缺点?

3、Android Framework

  1. AMS 、PMS
  2. Activity 启动流程,App 启动流程
  3. Binder 机制(IPC、AIDL 的使用)
    (讲讲 Linux 上的 IPC 通信,Binder 有什么优势,Android 上有哪些多进程通信机制?)
    1、项目中遇见了什么多进程场景?
    2、AIDL 是什么?解决了什么问题?
    3、谈谈对进程共享和线程安全的认知?
    4、什么是协程?
  4. 为什么使用 Parcelable,好处是什么?
  5. Android 图像显示相关流程,Vsync 信号等

4、三方源码

  1. Glide :加载、缓存、LRU 算法
    (如何自己设计一个大图加载框架)
    (LRUCache 原理)
  2. EventBus
  3. LeakCanary
  4. ARouter
重点:Router 原理,如何实现组件间的通信,组件化平级调用数据的方式。
复制代码
  1. 插件化(不同插件化机制原理与流派,优缺点。局限性)
  2. 热修复
  3. RXJava
    (RxJava 的线程切换原理)
  4. Retrofit
    (Retrofit 在 OkHttp 上做了哪些封装?动态代理和静态代理的区别,是怎么实现的)
  5. OkHttp 和 Volley 的区别。
    1、OkHttp 源码,网络缓存
    2、如果从网络加载一个 10M 的图片,说下注意事项
    3、安卓为啥要加签名机制

5、算法与数据结构

  1. 单链表:反转、插入、删除

  2. 双链表:插入、删除

  3. 手写常见排序、归并排序、堆排序

  4. 二叉树前序、中序、后序遍历

  5. 最大 K 问题

  6. 广度、深度优先搜索算法

  7. 可以去刷一下 LeetCode ,对自己提升也会比较大。

  8. String 转 int。 核心算法就三行代码,不过临界条件很多,除了判空,还需要注意负数、Integer 的最大最小值边界等;

  9. 如何判断一个单链表有环?

  10. 链表翻转;

  11. 快排;

  12. 100 亿个单词,找出出现频率最高的单词。要求几种方案;

  13. 链表每 k 位逆序;

  14. 镜像二叉树;

  15. 找出一个无序数组中出现超过一半次数的数字;

  16. 计算二叉树的最大深度,要求非递归算法。

  17. String 方式计算加法。

6、项目 & HR

  1. 项目开发中遇到的最大的一个难题和挑战,你是如何解决的。(95% 会问到)
  2. 说说你开发最大的优势点(95% 会问到)
  3. 你为什么会离开上家公司
  4. 你的缺点是什么?
  5. 你能给公司带来什么效益?
  6. 你对未来的职业规划?

下次更新内容章节为 Java 中的集合,我会根据内容多少决定分几篇文章去讲,大致内容如我整理脑图

为避免失联或想第一时间查看我的文章更新,可关注我的微信公众号 KevenZheng ,之后会陆续更新上述目录的内容,敬请关注。

如需转载,请联系我或注明出处!

关注下面的标签,发现更多相似文章
评论