以 29K 成功入职字节跳动,这份《 Android 面试笔记 》让我受益匪浅
回顾一下自己这段时间的面试经历,五月份的时候,因为资金链断裂导致我待了三年多的公司宣布了破产,刚开始离职后,我也尝试过出去面了几家,但面试过程中有好多面试题根本无从下手,结果咧,也在我的预料之内,匆匆忙忙的去面试灰溜溜的回来。中途有一家面试较好的公司打算给我 offer,但是工资有点糟糕,我也没有接受。
几次面试失败后,我开始了陷入了自我怀疑,好在身边朋友的劝导,最终还是走出了迷雾。后来,在痛定思痛后,决定还是面试现实,从头开始、狂补 Android 基础,花了 2 个多月把借助前段时间在某乎上面一位 Android 技术博主收藏过来的《 Android 面试笔记》吃透后,抓住 金九银十的首班车以 29 K 入职了字节跳动。
面经,我分享在了文中,答案,我会在后续更新,至于这份《Android 面试笔记》的话,知识点较多,我会在文章中展示一部分,需要阅读完整的《Android 面试笔记》的朋友注意:文末有完整版阅读地址
二、字节跳动—飞书部门 Android 面经
一面
一面是一个电话面试,下午 6 点左右特地找了一个地方电话面试,6 点准时电话就过来了,不得不说,字节跳动在面试这方面还是蛮准时的。。。
1、Object 的方法有哪些?
2、为什么要有 HashCode 方法,hash 算法的原理,在 Java 中哪些地方用到,进而问到了 HashMap 的源码
3、Java 有几种锁,synchronized 与 Lock 有什么区别,Lock 的实现原理,有没有碰到死锁的情况
4、Android 源码中用到了哪些设计模式,举例说明
5、一个 Android 正常启动有多少个线程?(这里当时是比较懵逼的,第一反应是一个主线程,然后觉得应该不止这么简单,想到应用 Activity 启动的话,应该还有 2 个 Binder 线程,可能一个管理 JVM 的线
程,面试官接着问还有哪些。。果断放弃不知道...)
6、Binder 机制的实现思想
7、简单描述 Https 的实现思路
8、描述下快速排序的思想,时间复杂度?什么场景对应着最坏情况?
9、给定无序数组和一个值,找到两个数和为值的元素,不能使用额外空间复杂度(不要使用 HashMap)
二面
在一面后的第四天,中午字节跳动某 HR 给我来了二面的电话,约我视频面试,问我晚上有没有时间,在相互交流沟通后,约了晚上 8 点钟的面试。
1、TCP/IP 四层模型,网络层和传输层有什么区别?网络层的主要工作是什么
2、socket.accept()函数对应着 TCP 三次握手中哪一次握手,哪个函数代表连接建立完毕,四次挥手的过程?
3、有做过哪些优化工作,卡顿优化,内存优化,启动优化,APK 体积优化,每个做了哪些工作
4、JNI 开发中有碰到什么问题?怎么定位 native crash
5、递归非递归反转链表
6、打印回环数组
三面
1、Looper 消息机制,postDelay 的 Message 怎么处理,Looper 中的消息是同步还是异步?什么情况下会有异步消息
2、事件分发机制的源码
3、android 的屏幕刷新机制,怎么优化 UI 卡顿情况
4、有没有使用过插件化框架,实现原理?
5、你在项目中碰到什么比较棘手的问题?怎么解决的?
6、找到一个无序数组中第一次出现最多次数的元素。
评论