
一面(~45min)
- 介绍项目,讲述实习的工作内容和感想(~10min)
- 什么是内存泄漏,Android里有哪些内存泄漏的场景,原因是什么
- JVM的GC过程,GC的算法都有哪些
- 进程和线程的概念,Android里怎样实现多线程?(Thread Handler AsyncTask IntentService等等)
- Handler的原理和使用
- Handler是怎么和线程绑定的(Looper),为什么Looper.loop()要设计成死循环
- Java的几种内部类,区别是什么
- Activity的生命周期和启动模式
- 写题:二叉树的右视图(层序遍历即可)
一面比较短,问的问题也比较基础,大概30分钟后开始二面
二面(~1h30min)
- 自我介绍
- 介绍项目,为什么要自学安卓(~5min)
- Android如何实现多进程,应用场景是什么(答的不好)
- Android的IPC机制(Binder)是否了解(答的也不好)
- 如何用两个队列(FIFO)实现栈(FILO)
- HashMap和HashTable区别,HashMap原理和实现,hash()的算法
- 如果自己设计hash算法怎么设计,为什么(答的素数取余)
- String的hashCode()和Object的hashCode()
- 虚拟内存和物理内存的概念和关系,内存分页的调度算法
- 怎么实现LRU缓存(参考leetcode T146)
- 可以自己写一个java.lang.Object类吗,系统会加载哪一个
- Java里泛型的实现
- 了解常见排序算法吗,手写一下快排
- Java里加锁的方式,synchornized关键字的原理,悲观锁和乐观锁都有哪些实现
- 死锁的条件和解决方法,讲讲银行家算法
- TCP的三次握手四次挥手,为什么要四次挥手
- TCP的流量控制算法(滑动窗口),拥塞控制算法
- 怎么解决用户高频点击打开新Activity导致的多实例问题(Activity启动模式)
- 怎么判断两个无环单链表是否相交
- 写题:leetcode 445
- 反问
二面问题量非常的大,集中在Java/OS/算法,但并没有特别难以回答的问题,认真准备的话大部分都能答出来。面试官也非常友好,给了很多引导和提示。 因为三面面试官的时间问题,约了两天后的三面
三面(~45min)
- 自我介绍
- 介绍一下实习做的工作,是自己完成的吗,遇到什么困难,成果怎么样
- RecyclerView怎么实现的item缓存,跟ListView有什么区别(因为项目用到了所以被问了)
- 写题:leetcode 1233
- 设计题:微信的联系人列表功能
(1)设计添加联系人的API(从可能的方式,数据形式,接口参数方面回答)
(2)怎么实现联系人列表的UI(答的RecyclerView)
(3)怎么实现A-Z首字母的快速定位功能 - 是自学的Android吗,为什么选择这个方向,有没有什么经验给同样想自学的学弟学妹
- 是哪里人,为什么想到上海来就业
- 反问
三面的问题不多,不过因为多数问题没有标准答案,难度其实高于一二面
结尾
大厂对计算机的基础知识的考察真的很深入,后面想了想确实,计算机的基础掌握牢靠了,在接触新的知识真的很快,计算机方面的知识又是更新特别快的,需要不断的学习。基础真的很重要。

