很多小厂没有大厂的命,却得了大厂的病
一面(104min)
- 自我介绍。
- 线程和进程的区别。
- 线程安全。面试官追问是否了解volite关键字,小金忘了没回答出来。面试官追问是否了解自旋锁,乐观锁,悲观锁等,小金回答了解但是没用过。
- http是用什么实现的。
- TCP和UDP的区别。
- TCP为什么是可靠的。注意拥塞机制涉及的算法(慢开始,拥塞避难,快重传,快恢复)。
- Get请求和Post请求的区别。注意Get请求比Post请求效率高,Post请求需要服务器返回100再发送数据处理,Get请求直接是通过URL。面试官追问是否知道其他请求方式,Put,Delete,Head。
- 项目中询问一个 A Activity 跳到一个 B Activity中,生命周期的走动,点击Back返回呢。如果一个 A Activity是透明的呢?如果 B Activity是一个Dialog呢?面试官追问横竖屏切换生命周期走动,以及是否了解onConfigurationChanged。
- HashMap的源码,扩容的条件。
- 算法两道,一道是和并两个有序链表,小金用的归并排序合并过程的思路写的(长时间用IDE,好多错误,但是面试官很有耐心帮我纠错)。一道是思路,将一段文本中的单词逆序输出,主要考察数据结构的知识,用到了栈和队列。
- 询问小金的基本情况,实习时间等。
- 反问环节:其实没问,面试官建议小金对常见的知识做深一步的理解,多看源码,多用记事本写代码,多看看基本的数据结构和算法。
二面(57min)
- 自我介绍。
- Android静态库和动态库的区别。
- Android中Binder机制。
- Android进程间的通信。
- 说说自旋锁,内部实现。
- 问了线程同步,小金又说了sychroized,还是参考那篇博客。
- 是否了解Java的atomic,以及好多很底层的东西,记不清了,大部分都没有回答出来。
- 算法题:求解矩形起点到终点的最短路径,只能向右或者向下走,这是一道简单的动态规划题。
- 询问小金的基本情况,实习时间等。
- 反问环节:询问小金想要加入还需要提升那部分的知识,面试官建议多参加实际的项目。
三面(40min)