首页 > 百度java开发一二面面经
头像
cctw_zed
编辑于 2020-07-23 12:13
+ 关注

百度java开发一二面面经

一面

1. 投递的岗位是java开发,地点在北京。自我介绍完之后,面试官询问了一下我的基本情况,问我有没有求职的具体的方向,比如偏算法、研发、数据库或者大数据,有没有自己的一些意愿。
2. 深挖项目。涉及到项目的思路、流程;过程中遇到的困难、如何解决的;如何提升性能的;所用到技术的底层原理等。(大概半小时)
3. final、finally和finalize的作用
4. synchronized和volatile的作用和区别
5. Java util包里面一些常见类的设计,我讲了HashMap相关内容。(底层结构、确定下标、扩容、线程不安全等等)
6. ConcurrentHashMap了解吗?(1.8之前分段锁,1.8之后CAS+synchronized,以及为什么会改)
7. CAS了解吗?优缺点?
8. 多线程编程写过具体代码吗?(写过简单的Web Server)
9. 那讲一讲BIO、NIO和AIO。(阻塞/非阻塞,同步/异步,然后分别讲各自原理)
10. JVM常用的垃圾回收算法。(各个算法及优缺点,用于新生代回收还是老年代回收,为什么?)
11. 平时的开发环境是Linux吗?熟不熟悉Linux的命令?给一个日志文件,统计一下UV和PV。(emmm 只会一些最基本的日常操作,这个不会呀。。)
12. 刚提到平时会看一些书,你最近在看什么书?之后有什么打算看的书?(最近看 深入理解Java虚拟机 和 并发编程的艺术嘛。。计划看看算法4)
13. 反问环节。期间问到如果能拿offer,毕业之前能否去实习。(emmm 下学期还有毕业论文,而且实验室也不会放呀)
14. 算法题目:百度热搜榜。简单来说就是:有一个大文件,记录一段时间内百度所有的搜索记录,每行放一个搜索词,因为搜索量很大,文件非常大,内存放不下,求搜索次数最多的TopN个搜索词。线下编码完成,半小时左右回复邮件。
思路:1. 根据每行单词的hash值将大文件分为若干小文件 2. 对于每个小文件,利用HashMap统计词频,然后利用优先队列取TOP N 3. 取每个文件的TOP N,利用优先队列得到总共的TOP N
(涉及到文件操作。。实在不太熟悉,花了五十分钟)

二面(一周后)

1. 自我介绍
2. 深挖项目。
3. synchronized与ReentrantLock的作用于区别,以及使用场景。
4. synchronized锁升级的详细过程。(无锁->偏向锁->轻量级锁->重量级锁)
5. 为什么synchronized之前是重量级锁。(底层使用mutex锁,涉及到用户态与内核态的转换,上下文切换消耗较大)
6. 为什么synchronized只有锁升级过程,没有锁降级过程?(没想过这个问题。。为什么呢。。)
7. 死锁的概念。如何避免死锁。
8. TCP/IP协议包含那几层?每一层有哪些协议?TCP/UDP区别,适用场景。
9. 系统设计:在线多人web版聊天室。可以看到所有人的发言,也可以看到聊天室的历史消息。如何设计?(emmm 没了解过这类题,拉胯。。。)
10. 认为自己的优势在哪?(自夸环节,当然得使劲夸咯hhhh。)
11. 反问环节。同样问到能否去实习的问题(是因为部门缺人吗。。)(上一面结束后,如果有下一面,会在一周内通知。)
12. 算法题目:给N个数组,计算笛卡尔积,并输出。A[1,2,3],B[4,5,6],C[7,8,9],输出 {1,4,7},{1,4,8},{1,4,9},{2,4,7}.... 应该是一个不用剪枝的DFS题目吧。

最后求一个三面,求来个offer呀!!!

更多模拟面试

全部评论

(8) 回帖
加载中...
话题 回帖

相关热帖

近期热帖

历年真题 真题热练榜 24小时
技术(软件)/信息技术类
查看全部

近期精华帖

热门推荐