java研发面经分享:滴滴、美团、网易、58赶集等

今年秋招我的面试大致结束了,差不多把提供北京java岗位的互联网公司大都投一遍,也获得了几个面试机会,以后可能不常上牛客网了,在这儿把面经都和大伙儿分享一下吧。先感谢下牛客网和众多牛友们,刷了大概有1千多题,妈妈再也不用担心我过不了在线笔试了~

1、滴滴

先吐槽下滴滴面试安排,如果你通过了一面,那么就优先安排后面的面试,所以导致还没一面的人就得一直苦等。那会儿我是下午一点去的,大概到了快4点才进行一面,后面就嗖嗖嗖地过关斩将到了hr面,也算是运气不错吧。

交叉1面

垃圾回收算法

(代码)01矩阵,相邻的1是一个岛屿,找出所有岛屿数(递归解决)

有关注过开源社区吗,都看过哪些源码

AtomicInteger实现原理(CAS自旋)

synchronized和reentrantLock区别

介绍spring的IOC和AOP,分别如何实现(classloader、动态代理)

redis如何处理分布式服务器并发造成的不一致(本身就是单线程序列化的隔离级别),如果数据库不提供隔离呢

OSGi的机制(因为简历写了)

交叉2面

2个鸡蛋,100高的楼,最少的次数测出鸡蛋碎掉的临界层,没碎的鸡蛋可以反复用(没做出,应该是14次,网上有解法)

大量字符串找出数量最多的K个,考虑内存放得下和放不下两种情况

解释mysql索引、b树,为啥不用平衡二叉树、红黑树(磁盘和内存的存储方式不同)

垃圾回收算法,为什么要分代处理

跳表(不熟,没继续)

IO(不熟,没继续)

epoll(不熟,没继续)

一致性hash

zookeeper如何同步配置(不熟,没继续)

讲下java锁的原理

ConcurrentHashMap原理

BOSS面

(代码)最长回文子串

GC停顿原因,如何降低停顿

JVM如何调优、参数怎么调

如何用工具分析jvm状态(visualVM看堆中对象的分配,对象间的引用、是否有内存泄漏,jstack看线程状态、是否死锁等等)

进程和线程区别

epoll和select区别(不熟,没继续)

解释mysql索引、b树

hr面

五个词来描述自己

长期的计划

兴趣爱好

期望薪水

对岗位的要求

已经拿到的offer

hr告诉我滴滴主要还是用c和php(看来我这次算是误打误撞),然后和我说php多快呀,多容易呀,要不要到碗里来?呵呵呵

java岗面

(代码)含Double数据的list,找出最长连续递增序列的长度(连续递增比较简单,看你代码质量)

找出最长递增子序列的长度,说思路(dp算法,复杂度O(n))

mysql中int的最大填充长度(我记得是255,被告知是错的),varchar不同编码下的存储字符个数

写SQL,多表连接查昨天的第二多的值

js题,考察闭包

2、美团

美团的面试安排在下午,不用早起真好~ 等候区就在1楼,工作人员供了面包和一次性杯子,旁边就是运动区,有跑步机、乒乓球桌、桌上足球及一些运动器材,感觉环境还是很不错的(此处应该吐槽下京东,场面极其混乱)。

面试一共三轮,会有工作人员叫名字让你进去面试,就是中间的等待有点久。每轮通过的话就会留下来接着下一面,没过的话工作人员会告诉你“很抱歉,你今天的面试已经结束了”,特别是在漫长的等待中,周围的人一个个被“很抱歉”,那个心理压力可不是一般大。然后就是全部的面试经过,大概整理了下,发现运气还不错,都可以答得上来。面试问题只是参照,面试官会根据你的简历来问针对性的问题,而你也可以引导他来问你擅长的领域,当然有些基础的东西还是必须了解的,比如jvm、spring框架、持久化框架、数据库之类的。

一面

介绍实习经历,讲项目

解释https (先公私钥加密,再对称加密) 为什么不直接公私钥

jvm中类加载过程,解释双亲委派加载,及类是在哪个加载器加载的

传值、传引用 传入对象引用,指向一个new的对象,问主函数里的会变吗

找出数组中最多的那个数,除了hashset还有没其他方法(只想到蒙特卡罗法)

(代码)输入合法的数字字符串,输出货币字符,就是每隔3位加个逗号,考虑边界处理

(代码)有1-10 10个数,和一个数sum,计算用10个数连加得到sum有多少种系数组合(递归)

二面

自我介绍,讲项目

spring中bean加载机制,bean生成的具体步骤

ioc注入的方式

spring何时创建applicationContext(web.xml中使用listener)

listener是监听哪个事件(ServletContext创建事件)

springMVC流程具体叙述下

synchronized和reentrantLock的区别,synchronized用在代码快、方法、静态方法时锁的都是什么

介绍ConcurrentHashMap原理,用的是哪种锁,segment有没可能增大(不会,只会增大每个segment中的entry数组)

如何实现高效的同步链表

(代码)层次遍历二叉树,偶数层输出逆序输出(队列,用一个标记记录每一层的结束,统一输出当前层)

三面

介绍实习经历,讲项目

(代码)给定一个字符串,写出所有可能的全排列(递归)

剩下的就是问一下hr面的问题:

怎么理解踏实,你在项目中哪儿体现到了

最近最有成就感的事

你的优点 缺点

最近在看的技术

是否写过其他个人兴趣的小项目

写技术博客吗,github呢

个人职位目标

三面的面试官还是很nice的,最后的部门好像也是由三面的来挑。面试结束第二天就让签了两方,待遇也没得谈。

3、网易

面试等待时间赶超了滴滴,上午10点等到下午两点才刚开始一面。hr面结束都5点多了,正赶上下班高峰期,公交又堵了好久,回去后感觉浑身都已经无力了。

一面

介绍了下阿里的实习项目,问了下对SOA和OSGi的认识,以及之间的关系

项目中遇到的最难忘的问题,如何解决的(网上搜索、问经验丰富的、断点调试跟进源码、技术论坛发帖)

问了擅长的java领域,针对性提问(jvm、容器、并发)

介绍jvm内存机制(把各个内存区域作用、回收算法、收集器分类统统说了一遍)

创建线程方式(实现runnable接口、集成Thread、线程池)

java都有哪些加锁方式(synchronized、ReentrantLock、共享锁、读写锁等)

想让所有线程都等到一个时刻同时执行有哪些方法(介绍了下CountDownLatch和CyclicBarrier)

volatile的作用(使变量对所有线程可见,同时禁止指令重排序)

都用过哪些java容器,LinkedList都一般都在什么时候用到(经常插入删除时、实现队列和栈时)

介绍ConcurrentHashMap(分段加锁,几乎每个面试都问这个。。。)

Object里头都有哪些方法,着重问了clone(深复制还是浅复制)、finalize(一般在什么时候用,回收时一定能被运行)

二面

问题和一面差不多,很多重复的就不说了

如何管理线程(介绍了各种线程池的实现)

如何让线程A等待线程B结束后再执行(join、单线程池),还反问单线程池真的可以吗,所以大致和他介绍了下阻塞队列的机制

如何优化jvm参数(堆大小、xmx一般和xms设成一样大、永久代大小、收集器选择、收集器参数、新生代对象年龄阈值等)

hr面

很少见的男hr,性格温和,谈起来很轻松愉快

介绍所有的项目

对在阿里的实习如何评价,对mentor如何评价

在阿里有没什么让你比较惋惜的地方(内部论坛资源非常丰富,都是大牛的知识帖,后悔看得太少)

喜欢何种风格的领导,是严格的技术型还是宽松的管理型

你的职业规划,转管理还是一直技术

喜欢的兴趣爱好

针对我写到的旅游又问了,去哪儿旅游过,通常都是如何准备一次旅行的(查各种攻略、做旅行计划,叫上小伙伴),是否写游记呢(很少),对写游记的人如何评价(为他们点赞~)

最近在看什么书籍呢(各种技术类书籍)

是否能提前来实习

已经拿到的offer

目标薪资

4、58赶集

58就在798旁边,面试完后特地去在寒风中感受了下艺术气息。签到的时候可以看到自己笔试的分数,貌似是按分数排的面试顺序。不想更加纠结所以放弃了二面。

一面

终于遇到一位年轻且头发还算茂密的面试官了,还蛮热情的

闲扯了下项目

介绍spring的IOC和AOP,容器的概念(本质就是applicationContext管理了classloader)

bean的创建过程

手写TCP三次握手(最好把状态也写出来),每次请求的序号是如何变化的

TCP如何控制拥塞(拥塞窗口、慢开始、拥塞避免、快重传、快恢复)

(代码)N个男生,N个女生,给出所有排列方式,其满足在任意i处(范围在[0,2n-1]),0-i的女生数都大于男生数(递归实现)

知道哪些排序算法,介绍一下快排

5、京东

在某天晚上突然收到第二天早上去京东面试的通知,而且用的还是电话语音,9月22日读成九点二二 是什么鬼!面试现场比较混乱,一边的人在排着队,一边是有负责人出来循环播放“XXX在吗”……当天只安排一轮面试,大约等了一小时才见到面试官,面试官貌似是做管理的,技术性问题不多。介绍完项目后提出了一些场景问你如何解决,如何实现分布式,一般在哪儿用redis等等,面试过程很短一下就结束了。回去后半夜又收二面通知,又是那个电话语音,我当时的内心是崩溃的……但是面试时间和美团的冲突了,并且根本找不到hr联系方式,京东的面试就在此止步了。

还有几家公司的面试,要么不大合适,要么就是跪了,就不细说了。希望大伙儿都能找到满意的工作,特别是到了校招后期,心态可能会变化比较大,可以来场说走就走的短途旅行缓解下压力,不要过于苛求自己,祝一切顺利!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值