2024年安卓最全字节跳动高工面试记,已拿-Offer-入职!,2024年最新面试官技巧问题及答案

尾声

开发是需要一定的基础的,我是08年开始进入Android这行的,在这期间经历了Android的鼎盛时期,和所谓的Android”凉了“。中间当然也有着,不可说的心酸,看着身边朋友,同事一个个转前端,换行业,其实当时我的心也有过犹豫,但是我还是坚持下来了,这次的疫情就是一个好的机会,大浪淘沙,优胜劣汰。再等等,说不定下一个黄金浪潮就被你等到了。

  • 330页 PDF Android核心笔记

  • 几十套阿里 、字节跳动、腾讯、华为、美团等公司2020年的面试题

  • PDF和思维脑图,包含知识脉络 + 诸多细节

  • Android进阶系统学习视频

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • Android打包哪些类型文件不能混淆?
  • Retrofit主要实现机制?
  • 动态代理静态代理区别?

→上面这坨都是从我做过的项目或用过的开源库引申出的问题,而且挑的都是不太偏业务且技术性强一些的,这其实要求日常在把事儿做成的基础上还得再多看下原理顺带自己动手探索下,明晰人家每一步是怎么互相关联推动直至最终搞定的,而不是加个dependency或copy下别人代码就完事儿嘞~

5.思维、架构

模块化怎么做的?怎么设计的?接口发现暴露怎么做?基于什么思想?MVC、MVP、MVVM应用和彼此本质区别?

→因为这不是那种确定性答案的问题,只能多实战+战后总结并深入思考才能出真知啦,

二面:

真是要了我半条命,耗时近2小时……

这面上来大概介绍了下自己,然后问了点我用过的东西比如Glide缓存特点?随后:你擅长Android中哪个方向呢?这问题我其实是按Android UI动画方面和移动端后台交互方案制定来预想过的,然鹅说完他挑了Android UI,噩梦就开始嘞- -直接他出效果我来想方案做。

第一个问题前他说,这个问题我问过很多人没几个能答出来的,你试试?

:呵呵🙄
:你看我这手机上这个launcher里应用抽屉(就是很多ROM都有的把很多APP管理归类的二级菜单功能)他在这ROM前一版是有个毛玻璃效果背景的,从系统ROM角度说下怎么做吧?

→这100%是我一点没做过的,面试官八成也知道,也是很多人在面试里会遇到的情况,这时候别慌,我们可以从知道的东西里去推,哪怕只把把思路展示出来也OK;比如这个肯定是FrameWork做系统统一渲染那里要做些事,那系统渲染是谁管呢,SurfaceFlinger呀,它怎么工作的呢?它哪一步改动一下是不是可能就达到这效果了呢?这种思考过程是一个高工所要必备的,也是需要日常在面对很多问题时要培养自己去练就的思考方法~ 事实证明,虽然有些细节我确实没涉及过,但至少思路策略以及知识迁移解决问题能力都得到了面试官的认可~

后面还有的UI相关的依旧是类似这种的两个大问题:实时的水面倒影效果怎么做?这里面实时更新的UI性能如何保证?→我所处情形和思路同上

再到后面是偏UI基础的考察:Measure、Layout、draw大流程、绘制顺序,基于这些说下TagLayout(FlowLayout)怎么写?

接着是算法题:俩线程分别持续打印奇数和偶数,实现俩线程的交替打印(从小到大)→计算机操作系统线程相关基本题目,你要觉得难只能说明基础瘸腿,赶紧补吧;操作系统+编译原理也是我面试别人过程中发现的大多数人的弱项

最后也是模块化、工程架构思想相关更细致的盘问,确实有些我之前没意识的问题被问及不过还是老方案:能想出来的就给方案,不能的就给思考过程。

三面:

整个Android端负责人面,可能是二面太太要命了,这面相比之下感觉在休息……

上来还是互相介绍,然后有个算法题解决个实际问题,因为我很快用知识迁移的思想把生产者消费者问题的解法用过来,讲的也很透彻,手写代码就省了,随后还是问问偏思想性的东西工程架构、之前提到的接口暴露又老生常谈,不过之前答的不太好我突然还是用知识迁移想了个好办法解决,对方也听后看似比较满意;

再然后还是擅长方向,因为二面真是被虐惨了,另外考虑到三面负责人的身份更关注一个人思想性、系统性的东西,所以毫不犹豫说了定移动端架构解决方案、前后台接口涉及那套,这个应该是很少有面试者会说的一点,我发现我说完面试官眼前放光😜

随即问题就是设计个IM客户端以及数据库架构吧,类似微信,偏上层业务部分的会话、联系人、通知、公众号如何存、分几张表,架构每一层都是啥,互相怎么交互工作?

还有是提个公司旗下产品做的不好的点,吐槽一下(有理由根据说服对方即可,最好是人难以意识到的点)。最终基本就是了解公司情况嘞,全聊完他都没商量就直接告知hr来跟我谈了,到这里基本可以知道就是稳了,国内公司hr很少有挂掉人的,尤其对于ByteDance这种缺人的地方,移动端又是稀缺中的稀缺~

hr面:

这面就是偏闲聊了,问问跳槽原因、个人爱好、个人职业规划、目前薪酬、跳槽薪酬要求,福利同步一下;这面稍微注意一个点吧,就是你首先要真诚,然后基于此尽量展示给对方的是你有活力、有上进心、对自己有想法也有期待、对于你来面试的地方也有兴趣;你给她的好感会帮助你在定薪过程中让她为你多多美言,当然主要还得看技术面,但这些小技巧也是有助力的,最终验证也是符合这点的,总的算起来我的薪资涨幅超过60%,二期要求最高直到40%,另外我还被赋予了选组的权力和期权,我感觉这里面或多或少都和我展示给hr以及前几轮面试官的我的精神面貌有关,有些认可是在面试过程中很多小细节(身体姿势、不经意的点头、微笑、手势、话语声调突变等)能看出来的~

!!!备注下,因为隔得时间略久,有些面试内容和考察点已然忘记的也就没往上写,整体的面试题量还是大过上述这些的!!!

最后的最后,再献上我个人面试别人经验以及这次被面试经历的一点要领总结吧:

对于社招,面试技术方向的,除了人工智能、算法那些其他真的不太看重学历,很多时候大家所认为的学历敲门砖本质上是企业为了节省面试成本所额外加入的坎,社招更多还是看工作经历和你的成长,这行业有句老话叫:从不看你起点在哪儿,而是看你能跑多块,那些还在为这点担心的更多是你自己还跑得不够快或跑错了方向,这是前提;

然后是方法,技术开发无论哪个方向都避不开的是计算机本源原理,有些很简单的情形就是本源原理的缩影,网络的分层,计算机体系结构上的分功用部件,你可能想过其中的联系?

【附】相关架构及资料

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

)**

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 15
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面我会使用 SQL 语句来实现这些操作: 1. 建立一个名为职工的表,它包含编号、姓名、性别、龄、工资、职称这六个字段。 ```sql CREATE TABLE 职工 ( 编号 INT PRIMARY KEY, 姓名 VARCHAR(20), 性别 VARCHAR(4), 龄 INT, 工资 DECIMAL(10, 2), 职称 VARCHAR(20) ); ``` 2. 向职工表中插入三条录,如上表所示;并查询所有职工信息,输出到控制台。 ```sql INSERT INTO 职工 VALUES (1001, '丁卫国', '男', 25, 2500, '助工'); INSERT INTO 职工 VALUES (1002, '张小华', '女', 30, 1000, '工程师'); INSERT INTO 职工 VALUES (1003, '宁涛', '男', 50, 600, '高工'); SELECT * FROM 职工; ``` 查询结果如下: ``` 编号 姓名 性别 龄 工资 职称 1001 丁卫国 男 25 2500.00 助工 1002 张小华 女 30 1000.00 工程师 1003 宁涛 男 50 600.00 高工 ``` 3. 将龄在45岁以上的员工工资增加15%,其他人增加10%,存入原表中,并查询更新后的所有员工信息,输出到控制台。 ```sql UPDATE 职工 SET 工资 = 工资 * 1.15 WHERE 龄 > 45; UPDATE 职工 SET 工资 = 工资 * 1.10 WHERE 龄 <= 45; SELECT * FROM 职工; ``` 查询结果如下: ``` 编号 姓名 性别 龄 工资 职称 1001 丁卫国 男 25 2750.00 助工 1002 张小华 女 30 1100.00 工程师 1003 宁涛 男 50 690.00 高工 ``` 4. 删除工资超过1500的员工录,并将每条录按照工资由大到小的顺序显示输出到控制台。 ```sql DELETE FROM 职工 WHERE 工资 > 1500; SELECT * FROM 职工 ORDER BY 工资 DESC; ``` 查询结果如下: ``` 编号 姓名 性别 龄 工资 职称 1002 张小华 女 30 1100.00 工程师 1003 宁涛 男 50 690.00 高工 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值