5年Android开发过关斩将:二本渣渣5面阿里P6,谁说越努力越贬值?(已获offer)

对于很多没有学历优势的人来说,面试大厂是非常困难的,这对我而言,也是一样,出身于二本,原本以为就三点一线的生活度过一生,直到生活上的变故,才让我有了新的想法和目标,因此我这个二本渣渣也奋斗了起来,竟拿下了阿里P6岗。


5年Android开发过关斩将:二本渣渣5面阿里P6,谁说越努力越贬值?(已获offer)_第1张图片

今天分享这波面经,主要是希望能够激励到同样被学历所困扰的技术人,能够对职业生涯和技术规划有一个参考价值,感谢!

以下整理的学习资料均免费分享,自行点击获取


一、面试阿里P6难在哪?(面试难点)

(1)难在“心态”

首先需要克服的第一关,实际上就是自己的心态。因为我是二本出身,base比较低,所以面试阿里本就是一件没太大底气的事情,更何况是高级开发岗,所以心里就更容易没底。因此,在准备面试之前,调整心态这件事情就做了很久,所以难在“心态”一点也没错,心态没调整好,面试几乎是没戏的。

(2)难在“要求”

其次就是要求,所谓的要求实际上就是阿里对岗位的任职要求,也就是作为开发人员,你掌握了多少技术栈?

首先,你简历上写的肯定要会,其次就是你要拥有一些亮点,也就是说对某个技术有深入的了解,这样才能给面试官耳目一新的感觉。

那么,面试阿里P6岗,需要掌握多少呢?

(1)原理问题

  • HashMap原理
  • ConcurrentHashMap 的实现原理
  • HashTable 实现原理
  • 广播发送和接收的原理了解吗?(Binder 机制、AMS)
  • 传统IPC 机制的通信原理(2 次内存拷贝)
  • Binder 机制的作用和原理?
  • LRUCache 原理
  • 图片加载原理
  • 讲讲AIDL?原理是什么?
  • 说一下泛型原理,并举例说明
  • Handler 的原理
  • Handler 引起的内存泄露原因以及最佳解决方案
  • Looper 死循环为什么不会导致应用卡死
  • AsyncTask 的原理
  • ThreadLocal 的原理
  • 什么是ANR ? 什么情况会出现ANR ?如何避免?
  • 一下Context
  • java 中的线程创建方式,线程池的工作原理
  • 线程同步机制与原理,举例说明
  • 内存回收机制与GC 算法;GC 原理时机以及GC 对象
  • 热修复原理
  • 插件化原理分析
  • 组建化原理
  • ARouter 路由原理:
  • 区别Animation 和Animator 的用法,概述其原理
  • 用过哪些网络加载库?OkHttp、Retrofit 实现原理?
  • volatile 的原理
  • synchronized 原理
  • 补间动画实现原理
  • MVC MVP MVVM 原理和区别

(2)算法问题

  • 排序算法有哪些?
  • 最快的排序算法是哪个?
  • 手写一个冒泡排序
  • 手写快速排序代码
  • 快速排序的过程、时间复杂度、空间复杂度
  • 手写堆排序
  • 堆排序过程、时间复杂度及空间复杂度
  • 写出你所知道的排序算法及时空复杂度,稳定性
  • 二叉树给出根节点和目标节点,找出从根节点到目标节点的路径
  • 给阿里2 万多名员工按年龄排序应该选择哪个算法?
  • GC 算法(各种算法的优缺点以及应用场景)
  • 蚁群算法与蒙特卡洛算法
  • 子串包含问题(KMP 算法)写代码实现
  • 一个无序,不重复数组,输出N 个元素,使得N 个元素的和相加为M,给出时间复杂度、.
    空间复杂度。手写算法
  • 万亿级别的两个URL 文件A 和B,如何求出A 和B 的差集C(提示:Bit 映射->hash 分组->
    多文件读写效率->磁盘寻址以及应用层面对寻址的优化)
  • 百度POI 中如何试下查找最近的商家功能(提示:坐标镜像+R 树)。
  • 两个不重复的数组集合中,求共同的元素。
  • 两个不重复的数组集合中,这两个集合都是海量数据,内存中放不下,怎么求共同的元
    素?
  • 一个文件中有100 万个整数,由空格分开,在程序中判断用户输入的整数是否在此文件
    中。说出最优的方法
  • 一张Bitmap 所占内存以及内存占用的计算

二、阿里面试题(共5面)

阿里一面:

一面:电话面,大约1h

0. 说说自己写的最复杂的一个页面
1. Java常见的集合?Android里面的集合用过吗?比Java的有什么优势
2. 进程间通讯的几种方式,项目中有用过吗
3. 图片加载用的什么?Glide,Glide的优点,生命周期是如何绑定的?Glide的缓存?LruCache的底层实现?LinkeHashMap,LinkedHashMap的底层实现?
4. 如果显示一个1:1的图片?自定义View重新测量宽高,约束布局?约束布局的好处?主要在项目中用在哪里?LayoutAnimation用过吗?MotionLayout用过吗?
5. 简述handler,创建Message的方式,这种设计是什么设计模式?子线程怎么创建Handler?Looper为什么不会阻塞主线程
6. 一个abc的Activity任务栈怎么启动一个def的任务栈
7. 设计模式,说几个常用的设计模式
8. 说说MVVM,jetpack,kotlin
9. 说说AndroidX
10. 热修复
11. Activity的启动流程
12. ViewPager Pool了解吗

阿里二面:

二面-五面现场面,一共面了将近4个小时,下午3点半开始到7点多

二面:
1. JVM:gc算法,gc分代
2. java的泛型,super和extend的区别?泛型擦除
3. HashMap的原理?怎么保证线程安全?HashTable、ConcurrentHashMap内部怎么实现的?分段锁、共享锁、公平锁?
4. 自定义View的流程?onMeasure怎么测量的?MeasureSpec的三种模式?invalidate、postInvalidate、requestLayout的区别?
5. 代理模式
6. leakcanary的工作原理
7. synchronized的工作原理
8. OkHttp的优点,回答的不好,可能是继续想问Http相关的,但是回答的不太好,所以问的不是很多
9. 又问到了Handler,几乎所有能问的都问了
10. Binder的通讯过程:具体server和client的通讯,为什么是一次拷贝
11. 如何加载大图?图片压缩的几种方法?采样率压缩是利用的哪个类,具体怎么设置的
12. 内存泄漏
13. 独立开发的项目架构怎么设计的
12. 算法题:判断链表有环

阿里三面:

0. 这一面主要问项目,给你的压力感比较强,项目中涉及的技术难点
1. 结合项目问,为什么这么设计?让你去优化,你怎么优化,引导你用一个合理的更好的方式去优化,数据库的设计等
2. 在公司做了什么事情,各个系统业务线都是做什么的,你的绩效

阿里四面:

0. 聊生活,技术和难点实现
1. 有什么优点/缺点
2. 怎么看待加班
3. 工作中遇到的最大的挑战/困难
4. 架构设计的基本原则
5. 架构设计需要考虑的问题
4. 直播的整个流程?是自己实现的吗
5. 视频卡顿怎么处理?
6. OkHttp网络请求的整个流程

HR面:

0.为什么来阿里?
1.之前没考虑过阿里吗?
2. 毕业这么久了,你觉得自己最大的改变是什么?
3. 用一句话总结一下自己


三、拿下阿里P6岗offer前,我做了些什么?

(1)准备简历

简历是门面,更是敲门砖,能否拿到大厂的面试机会,就要看自己的简历如何,抛开学历意外,大厂最看重简历是否有亮点,因此我们对简历内容要有准备,对自己的突出点,包括技术、个性上的亮点,要练习表达,避免临时组织语言。

(2)提升技能

实际上我有个阿里的朋友很早之前就向我透露过,很多人认为大厂看重学历,但实际情况并不完全是,在阿里只以能力论英雄。所以,在日常生活中,通过不断地学习,提升自己的能力,努力去拉进自己与目标值的距离,这是很有必要的,也是未来的必然趋势。

关于提升技能,我的做法:

  • ①阅读实战文档
  • ②读一些源码
  • ③读一些技术笔记

(3)猛刷面试题

对于base不是太好的人来说,刷面试题实际上是最具有“急救”效果的办法,因此在面试阿里前,我是刷了不少面试题的,目的倒不是希望面试时能被问到原题,而是对大厂面试有一个相应的了解,清楚阿里面试会问一些什么,涉及到哪些技术栈等。

关于刷题,我有话要说:

  • ①Android核心面试知识点整理
  • ②算法部分(LeetCode+算法的乐趣)
  • ③BAT大厂面试真题+专题训练

做个总结

很多学历不太好的人,可能对自己没有太大的信心,实际上任何事情都有“奇迹”发生,而这个“奇迹”关键还是要靠自己去创造。无论你是小白菜鸟,还是技术大牛,日常都不能够落下学习这件事情,一旦落后下来,就容易遭到淘汰。

以上我的经历希望能够给大家带来帮助,最后,在这里我也分享一份干货,大佬收录整理的Android学习PDF+架构视频+源码笔记,还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习

如果你有需要的话,可以点赞+评论关注我,私信【资料】获取或者自行下载获取

你可能感兴趣的:(5年Android开发过关斩将:二本渣渣5面阿里P6,谁说越努力越贬值?(已获offer))