最近在后台上看到有很多人私信留言,说在面试或者晋升考核中都遇到了关于Handler、Binder 机制的难题,相信大家已经在为金三银四这个旺季做准备了,现在面试官的问题都是根据你做过的项目进行深入探讨,如若对技术原理和底层逻辑没有深入了解的话,那么你通过面试的机会会显著下降
近期也是收集并整理了关于 Android Framework 的逻辑知识点总结和 Handler、Binder机制的学习笔记,相信能够解决大家对底层逻辑,技术原理,源码解析,面试真题等等相关技术知识点的不够了解透彻的问题
面试真题实例面试官问:Handler被设计出来的原因?有什么用?● 一种东西被设计出来肯定就有它存在的意义,而Handler的意义就是切换线程
● 作为Android消息机制的主要成员,它管理着所有与界面有关的消息事件,常见的使用场景有:
● 跨进程之后的界面消息处理
● 比如Activity的启动,就是AMS在进行进程间通信的时候,通过Binder线程 将消息发送给ApplicationThread的消息处理者Handler,然后再将消息分发给主线程中去执行。
● 网络交互后切换到主线程进行UI更新
● 当子线程网络操作之后,需要切换到主线程进行UI更新
● 总之一句话,Hanlder的存在就是为了解决在子线程中无法访问UI的问题
面试官问:Handler线程是如何切换的?● 假设现在有一个线程A,在A线程中通过Looper.prepare和Looper.loop来开启Looper,并且在A线程中实例化出来一个Handler。Looper.prepare()方法被调用时会为会初始化Looper并为ThreadLocal 设置Looper,此时ThreadLocal中就存储了A线程的Looper。另外MessageQueue也会在Looper中被初始化
● 接着当调用Loop.loop方法时,loop方法会通过myLooper得到A线程中的Looper,进而拿到Looper中的MessageQueue,接着开启死循环等待执行MessageQueue中的方法。 (3)此时,再开启一个线程B,并在B线程中通过Handler发送出一个Message,这个Message最终会通过sendMessageAtTime方法调用到MessageQueue的equeueMessage方法将消息插入到队列
● 由于Looper的loop是一个死循环,当MessageQueue中被插入消息的时候,loop方法就会取出MessageQueue中的消息,并执行callback。而此时,Looper是A线程的Looper,进而调用的Message或者Handler的Callback都是执行在A线成中的。以此达到了线程的切换
面试官问:Handler内存泄漏的原因是什么?● 通常在使用Handler的时候回通过匿名内部类的方式来实例化Handler,而非静态的匿名内部类默认持有外部类的引用,即匿名内部类Handler持有了外部类。而导致内存泄漏的根本原因是是因为Handler的生命周期与宿主的生命周期不一致
● 比如说在Activity中实例化了一个非静态的匿名内部类Handler,然后通过Handler发送了一个延迟消息,但是在消息还未执行时结束了Activity,此时由于Handler持有Activity,就会导致Activity无法被GC回收,也就是出现了内存泄漏的问题
面试官问:什么是 Binder?● 直观来说,Binder 是 Android 中的一个类,它继承了 IBinder 接口
● 从 IPC 角度来说,Binder 是 Android 中的一种跨进程通信方式,Binder 还可以理解为一种虚拟的物理设备,它的设备驱动是/dev/binder,该通信方式在 linux 中没有
● 从 Android Framework 角度来说,Binder 是 ServiceManager 连接各种 Manager(ActivityManager、WindowManager,etc)和相应ManagerService 的桥梁
● 从 Android 应用层来说,Binder 是客户端和服务端进行通信的媒介,当你 bindService 的时候,服务端会返回一个包含了服务端业务调用的 Binder 对象,通过这个 Binder 对象,客户端就可以获取服务端提供的服务或者数据,这里的服务包括普通服务和基于 AIDL 的服务
面试官问:为什么要使用 Binder?● 性能:移动设备中如果广泛的使用跨进程通信机制肯定会对通信机制提出严格的要求,而 Binder 相比较传统的进程通信方式更加的高效
● 安全:由于传统进程通信方式没有对通信的双方和身方做出严格的验证,只有上层协议才会去架构,如 socket 连接的 IP 地址可以人为的伪造。而 Binder 身份校验也是 android 权限模式的基础
面试官问:Binder 的工作流程是什么样的?● 性客户端首先获取服务器端的代理对象,所谓的代理对象实际上就是在客户端建立一个服务端的“引用”,该代理对象具有服务端的功能,使其在客户端访问服务端的方法就像访问本地方法一样
● 性客户端通过调用服务器代理对象的方式向服务器端发送请求
● 性代理对象将用户请求通过 Binder 驱动发送到服务器进程
● 性服务器进程处理用户请求,并通过 Binder 驱动返回处理结果给客户端的服务器代理对象
由于文章篇幅有限,文档的资料内容较多,其他内容仅以图片形式进行展示
结语
随着面试过程中你的回答,面试官就会联想到更多的技术知识点,以此来了解你的技术面有多广,适不适合该档位,或者能不能往更高的职位上发展,全方位地考察你对技术的理解深度,以及解决问题的能力
更多关于Android面试题目的答案我都已经整理到了本地PDF文档中,这里由于篇幅原因没有一一把答案贴上来,需要完整文档的朋友们私信我发送:“Android面试真题”
,