小米Java一面(互联网三部),攒波人品
1. 自我介绍
2. spring的特点,为什么要用spring,反射的原理,从JVM层面上解释
3. 数组和链表使用场景的区别,同样的数据,两个数据结构存储需要大小是否一样
4. hashMap的流程,从数据的插入,链表的树化,再到扩容
5. hashMap有什么性能上的问题,(hash冲突),怎么解决(loadfactor,扰动函数)
6. StackOverflow是什么意思,OutOfMemory是什么意思
7. 垃圾标记算法,在进行可达性分析的时候会将对象放到什么数据结构中去
8. 垃圾清理算法,标记清楚,标记整理,复制,这三个算法的区别,从时间复杂度和空间复杂度来区分
9. 多线程造成线程不安全的原因是什么
10. volatile和Synchronized的区别是什么
11. 以后发展的方向,有没有考虑安卓,最近再看什么书
12. 一个算法,口述:有一个字符串,由26个字母组成,每个字母出现次数未知,设计算法,将26个字母按出现的频率由高到低排序
13. 有没有参加过比赛,数学建模,有没有专利
14. git的merge操作
13. 反问
总的来说还是比较基础,有的地方比较深入,,,不说了,我去补JVM了