百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

一普通安卓程序员的八次大小厂面试复盘,你的知识体系需要扩展了

xsobi 2024-12-11 17:50 2 浏览

写在前面

(全文约4k字)
总共是面了8家,(2小,4中,2大厂)

小的都拿下了,4中里3个一轮游,1个三轮游。2大的都谈薪了。

小公司会比较偏重于业务,面试上也偏重业务,比如做了什么,大概方案,用了哪些库,库的原理。

这些基本上会集中在 图片处理,网络封装,自定义view这几个部分。

大厂会从业务入手,递进深入到原理及相关知识点,尤其集中在原理部分,这里对平时源码阅读有一定要求。

或者直接问对xxx源码有没有了解。

比如一个handler机制,因其涉及的地方特别多而且很容易展开,想完美答好,真的不是一次两次就能行的。

建议每次面试完,都及时对面试内容进行回忆记录,当前这里不是为了泄题漏题,以后吹牛逼,这个没有任何意义。

目的是进行复盘,打磨自己的回答。

目录

  • 简历书写
  • 面试原题
  • 算法刷题
  • 学习总结

简历书写

强烈建议,把自己的强项,亮点加粗注明放在简历前面,大家都很忙,也很烦躁,让人一眼就看到优点,对双方都友好。

因为我对安卓性能优化方面感兴趣,平时工作也花了很多时间在这里,所以我会在简历上突出说明,我做了内存优化,熟练掌握使用xxx,内存性能提升xxx。

(因为这里的内容是可控的,如果面试官对你感兴趣,这里的回答你也是能提早准备好的)

项目经历如何写?建议按照是什么,做了啥,有啥数据指标佐证的方式去写。

比如,我做了xx项目,负责xx模块,使用了xxx框架,可配合xx做xxx,效率提高xxx%

面试—字节

字节一轮

1.先聊简历。

2.聊性能优化方面的问题,我这边体系化展开讲卡顿,瘦身,内存,crash等方面的优化经验。

3.sychronized,volatile区别?
这里可以体系化的回答,主要从JMM角度去回答,最后深入到字节码层面的区别。因为提到了修饰的范围有差别,就有了下一题。

4.对于锁的对象的不同,效果会有什么差别。

5.讲一下Handler机制。
这个问题问得太多了,一定要去看一回源码。
重点答的是MessageQueue这块,包括什么时候空闲,阻塞。
发散讲了线程相关的ThreadLocal,还有IdleHandler

6.出了一个设计题,当你的服务商出现问题,设计一个网络请求可用性的兜底方案。
大概从HttpDNS,域名容灾等方面回答吧。

7.设计一个方案,apk已经发出去了,java代码是最新,但是分包下发的so文件是旧版本,如何做一个兼容方案,保证兼容可用。
这里没答好,我也忘了怎么答的了。

8.Java类加载机制。

这是个基础概念题,没答好,回答的双亲加载机制。
然后引出PathClassLoader,DexClassLoader的区别,一个dex的加载到一个java类的加载过程。

9.一道算法题。

字节二轮

1.聊简历。

2.性能优化,展开讲了卡顿,内存。

3.数据结构的题,hashCode的扰动算法,涉及到一个数字,31,这个31是怎么来的?

4.类的static属性字段,比如 public static int a = 1,被赋值几次?
这个需要对类的加载机制有了解。

5.多个Activity共同bind一个service,一个Activity destory,问service的情况。
这里就是问service的生命周期,考察bind跟start的区别。

6.装饰器模式,跟代理模式的区别。
考察对常用的设计模式

7.okhttp的缓存逻辑实现。
我以为是问的 链接缓存跟io缓存,我回答的是连接池复用跟 okio的io复用。
后来提醒是cache,就回答CacheInterceptor,及其源码实现。

8.SharedPreference的commit ,apply区别。

9.SharedPreference的其性能问题。
apply的anr是有一个字段,会block住主线程,需要清理queuedWork队列。

10.SharedPreference线程安全性,还有是否进程安全,SharedPreference锁的对象是谁?

11.synchornized锁对象,汇编实现。volatile的汇编实现。

12.volatile 修饰 boolean能保证原子性么?

13.Android有哪几种动画。

14.设计题,设计一个埋点数据上报库,需要哪几个模块,提供哪样的接口。

15.算法题,生产消费者模型。

16.ConcurrentHashMap的相关。
包括实现原理,put方法,树化,扩容,继承了谁,扩容的时候,其余桶怎么感知。

17.安卓打包签名v1,v2,v3的区别。

字节三轮

1.装饰器模式,适配器模式区别。举个Android或java里的应用例子。
2.单例的优缺点。
3.架构有做过么。
4.说一下项目,项目中最能体现你能力的事情。
5.平时怎么学习的。
6.以后的职业规划
7.离职原因
8.插件化,做过插件化么,了解的主流方案?
9.算法题。

因第三轮挂了,捞出来换岗位再战。

字节加餐一轮(这轮面了175分钟,记忆深刻)

基础题目

1.聊聊平时做过的性能优化。

2.界面卡顿
从ViewStub源码开始谈LayoutInflate的整个过程
包括xml的解析,如何解析tag,细节到里面哪些特殊tag。

3.xml的解析耗时在哪些方面,反射,读文件,解析。

4.如何优化这个过程:xml在编译期就生成为class文件,那这是gradle编译的哪个阶段做这个事情。

5.checkthread的问题,从Window到ViewRootImpl的创建,几者之间的关系。

以上这是绘制相关,然后是渲染。

6.矢量图的原理。

7.canvas怎么来的。

8.Window跟View的关系。

9.硬件加速原理。

10.双缓冲机制。

11.丢帧的原因。

12.帧数计算。

13.设计如何检测过度绘制的工具,要具体到View。

14.blockcanary原理,目的。

15.Listview的滑动优化,比如一个emoji可以用TextView渲染,也可以用ImageView渲染,哪个更优。

16.Toast为什么不需要权限就可以显示。

17. Window BadTokenExcetion的原因。

18.怎么实现悬浮窗。

启动加速

1.怎么做app启动加速

我的回答说利用IntentService,就是异步加载机制。但是还不够。

2.引导我从app启动流程开始讲一遍,看从启动流程上能不能找到方法。

3.zygote的内部实现,zygote.fork有没有了解。

4.zygote跟ams的通信方式用的是什么。

5.整个启动过程中,mHandler做哪些事。

6.设计一个工具,监控启动时间,粒度要求在方法级别。

内存相关

1.讲下内存泄露。以handler匿名内部类做例子讲。泄露链是怎样的。

2.looper.prepare干了啥。

3.ThreadLocalMap的实现。

4.leakcanary原理。

5.为什么要做抖动的检查,有啥用。

6.为什么会出现抖动。

7.线上有泄露,怎么收集,排查,设计方案。

稳定性

1.解决线上稳定性bug的方法论。

2.讲个能体现亮点的解决线上bug的案例。

3.给了一个具体案例,让我现场分析原因。

主要考察思维方式吧。

4.怎么收集java的crash。

5.怎么收集native的crash。

6.用线程安全的数据结构,ConcurrentHashMap会出现modifyCountException么?

ANR相关

1.常见的anr问题怎么解。

2.不常见的anr,比如 MessageQueue.nativePollOnce都很正常,怎么去定位,如果是线上,怎么去收集。

3.ANR的原因

4.IntentService会ANR么,讲内部实现。

保活相关问题

1.杀进程机制的源码。
2.进程优先级。
3.怎么提升优先级。
4.常见的保活手段。

我这里着重讲了Tim的保活原理。还有第三方库Leonic的原理。

APP瘦身相关

1.andRes原理。
2.proguard源码。
3.Facebook 的redex,字节的bytex原理。
4.multidex原理。
5.很多资源包,如何瘦身。

问了一下我自己维护的github库相关问题

1.防多开原理
2.检测模拟器原理
3.查root权限,如果是自编的rom怎么处理。

聊了下简历里的经历

1.contentProvider的初始化时机。

这里主要是问我LeakCanary 1.* 跟2.*有啥不同引出的问题。

2.LocalBroadcast 和Broadcast的区别。

3.xposed的原理。

4.beforeMethodHooked,xposed内部做了什么事

5.免root hook框架 legend的源码实现。
记不太清,好像我说的是native方法指针的变更。

6.一道算法。

7.设计一个埋点库。 需要哪些模块。

8.设计一个组件,统计activity的前台时长,fragment的前台时长。

字节后续的面试我忘了记录复盘了,现在也记不住了。这一轮面试反正是把我榨干了。

最后进入谈薪阶段。只不过没谈拢,哈哈。

面试—鹅厂

最后就是我一直想去的粤海公仔厂了。

这里面试具体轮次我就不细说了。题目其实也都是那些题目,重点提供平时要学习的方向吧。

1.聊简历,性能优化。

2.view的绘制流程,尽可能越详细,越全面越好。
因为有了字节之前的面试经验,这里聊了很多view相关的。

大概从ActivityThread讲起,到Window,WindowManager,ViewRootImpl,
setContentView内部实现干了什么,LayoutInflater。

下发到requestLayout,checkThread,scheduleTraversals ,同步屏障消息
双缓冲, vsync信号,最后再performSechdules...

这里真的是要求自己平时除了写界面,也一定要深入源码进行学习。
很多奇奇怪怪的业务问题,真的就是靠读源码解决。

3.问网络优化,当网络带宽足够大,信号足够好,下载大文件,怎么快?

开多个链接,wifi+4G同时,分片下。
协议层 ,udp去下,本地做完整性校验,我记得qq客户端时这样做的。
m3u8的思想去下。

4.apk安全措施,当apk已经被破解了,怎么处理?
我回答借助v1签名思想,本地做对文件md5的校验。或者借助v3的思想,连续签名。

5.两个设计模式的区别。具体哪两个我忘了。

6.三道算法题

第一题写一个必然死锁的代码。讲一下解决死锁的方式。锁对象的不同的区别。

第一个出现的字符。

数组里的元素,组合起来求最大值。

7.checkThread里的thread是什么时候被赋值的。

8.讲下数字证书是什么。

9.解决内存抖动的实际案例。

10.降低bug的实际案例。

11.设计一个如何处理 app接收到服务器脏数据的方案。

12.设计一个云相册。

13.classLoader机制的原理。

14.硬件加速的底层实现。

15.操作系统相关问题。

16.如何处理多语言问题。

17.jvm虚拟机相关问题,具体忘了。

18.职业规划相关。

最后欢迎大家来鹅厂,有一说一不吹牛逼,这里同事真的很不错。

关于算法

多说两句,客户端要学算法,不是说算法没用,你知道什么叫树的遍历你就能理解viewTree解析过程。

而且在大家层次不齐的情况下,用算法打回同一层次,看看谁的逻辑性强,代码书写风格好,这是对面试筛选有好处的。

谁都会说,买菜要用高数嘛?但是人家会你不会,那就是在面试上吃亏。

正题,我的算法刷题路程。

剑指offer来入门:https://cyc2018.github.io/CS-Notes/#/README

里面有很多题,你在力扣评论区可以看到各种解法,建议多看各种解法,体会不同的思路。

刷题的方式,一定要自己动手写代码,调试,运行。

可以自己创个小库,督促自己提交。

也顺便把常见的设计模式复习了。

差不多刷完了基本的排序,遍历,贪心,局部最优等思想,也就有个一百来道题了。

此时面对面试,也就有个眼熟了。真心不建议采用突击的方式,应该要做一个长期写题的规划。

学习总结

我把锁相关,线程相关, Handler机制等Android相关的知识,以题目入手,递进发散的方式做了一个平时我学习的索引。

Android进阶架构师七大专题学习索引

客户端开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

系统学习方向:

  • 架构师筑基必备技能:深入Java泛型+注解深入浅出+并发编程+数据传输与序列化+Java虚拟机原理+反射与类加载+动态代理+高效IO
  • Android高级UI与FrameWork源码:高级UI晋升+Framework内核解析+Android组件内核+数据持久化
  • 360°全方面性能调优:设计思想与代码质量优化+程序性能优化+开发效率优化
  • 解读开源框架设计思想:热修复设计+插件化框架解读+组件化框架设计+图片加载框架+网络访问框架设计+RXJava响应式编程框架设计+IOC架构设计+Android架构组件Jetpack
  • NDK模块开发:NDK基础知识体系+底层图片处理+音视频开发
  • 微信小程序:小程序介绍+UI开发+API操作+微信对接
  • Hybrid 开发与Flutter:Html5项目实战+Flutter进阶

我把常见的数据结构,也归纳了一个索引

Java学习索引

接下来就是深入到app启动,绘制渲染,AMS等问题做了一个集中索引。

Android framework学习索引

我自己的Android源码阅读

Android源码学习索引

“编程语言是程序员的表达的方式,而架构是程序员对世界的认知”。所以,程序员要想快速认知并学习架构,读源码是必不可少的。阅读源码,是解决问题 + 理解事物,更重要的:看到源码背后的想法;程序员说:读万行源码,行万种实践。

整理的面向面试的阅读第三方库笔记

内容详实,涵盖了和Android开发相关的各个源码库。不仅深入浅出地分析源码,还记录了大佬们在使用时遇到的问题,并提供了解决的方法。

一共分为十个章节,包含Glide、LeakCanary、ARouter、EventBus、Retrofit源码详细解析,以及它们的使用,和一些容易遇到的问题。

以上内容均免费分享给大家,需要完整版的朋友,直接转发+点赞+私信回复【资料】一键领取!!!

相关推荐

js向对象中添加元素(对象,数组) js对象里面添加元素

一、添加一个元素对象名["属性名"]=值(值:可以是一个值,可以是一个对象,也可以是一个数组)这样添加进去的元素,就是一个值或对象或数组...

JS小技巧,如何去重对象数组?(一)

大家好,关于数组对象去重的业务场景,想必大家都遇到过类似的需求吧,这对这样的需求你是怎么做的呢。下面我就先和大家分享下如果是基于对象的1个属性是怎么去重实现的。方法一:使用.filter()和....

「C/C++」之数组、vector对象和array对象的比较

数组学习过C语言的,对数组应该都不会陌生,于是这里就不再对数组进行展开介绍。模板类vector模板类vector类似于string,也是一种动态数组。能够在运行阶段设置vector对象的长度,可以在末...

如何用sessionStorage保存对象和数组

背景:在工作中,我将[{},{}]对象数组形式,存储到sessionStorage,然后ta变成了我看不懂的形式,然后我想取之用之,发现不可能了~记录这次深刻的教训。$clickCouponIndex...

JavaScript Array 对象 javascript的array对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

JavaScript中的数组Array(对象) js array数组

1:数组Array:-数组也是一个对象-数组也是用来存储数据的-和object不同,数组中可以存储一组有序的数据,-数组中存储的数据我们称其为元素(element)-数组中的每一个元素都有一...

数组和对象方法&数组去重 数组去重的5种方法前端

列举一下JavaScript数组和对象有哪些原生方法?数组:arr.concat(arr1,arr2,arrn);--合并两个或多个数组。此方法不会修改原有数组,而是返回一个新数组...

C++ 类如何定义对象数组?初始化数组?linux C++第43讲

对象数组学过C语言的读者对数组的概念应该很熟悉了。数组的元素可以是int类型的变量,例如int...

ElasticSearch第六篇:复合数据类型-数组,对象

在ElasticSearch中,使用JSON结构来存储数据,一个Key/Value对是JSON的一个字段,而Value可以是基础数据类型,也可以是数组,文档(也叫对象),或文档数组,因此,每个JSON...

第58条:区分数组对象和类数组对象

示例设想有两个不同类的API。第一个是位向量:有序的位集合varbits=newBitVector;bits.enable(4);bits.enable([1,3,8,17]);b...

八皇后问题解法(Common Lisp实现)

如何才能在一张国际象棋的棋盘上摆上八个皇后而不致使她们互相威胁呢?这个著名的问题可以方便地通过一种树搜索方法来解决。首先,我们需要写一个函数来判断棋盘上的两个皇后是否互相威协。在国际象棋中,皇后可以沿...

visual lisp修改颜色的模板函数 怎么更改visual studio的配色

(defunBF-yansemokuai(tuyuanyanse/ss)...

用中望CAD加载LISP程序技巧 中望cad2015怎么加载燕秀

1、首先请加载lisp程序,加载方法如下:在菜单栏选择工具——加载应用程序——添加,选择lisp程序然后加载,然后选择添加到启动组。2、然后是添加自定义栏以及图标,方法如下(以...

图的深度优先搜索和广度优先搜索(Common Lisp实现)

为了便于描述,本文中的图指的是下图所示的无向图。搜索指:搜索从S到F的一条路径。若存在,则以表的形式返回路径;若不存在,则返回nil。...

两个有助于理解Common Lisp宏的例子

在Lisp中,函数和数据具有相同的形式。这是Lisp语言的一个重大特色。一个Lisp函数可以分析另一个Lisp函数;甚至可以和另一个Lisp函数组成一个整体,并加以利用。Lisp的宏,是实现上述特色的...