专栏首页Java架构学习路线2019年美团、滴滴、蘑菇街Java岗9次面试总结
原创

2019年美团、滴滴、蘑菇街Java岗9次面试总结

大概在三月份开始面了几家互联网公司,主要方向是java后端和大数据开发,最近整理学习资料,都快秋招了,发的有点晚了,不过还是想分享一下。美团,滴滴,蘑菇街等公司的面经。

美团

一面

聊你最熟悉的项目和技术。

项目中为什么要使用spark。

spark怎么划分stage,宽窄依赖,聊源码

spark提交一个作业的执行流程(单机模式)

spark driver节点,worker以及master节点遇到故障如何解决。

spark checkpoint原理

聊JVM内存划分与GC算法。

JVM中为什么需要使用分代收集算法,有什么好处。

手撕代码:

输入一个链表和一个定值x,要求将值小于x的所有节点置换到x的左侧,值大于x的所有节点置换到x右侧,另外需要保持原有前后关系。比如:

输入:1->4->3->2->5->2 and x = 3,

输出:1->2->2->3->4->5.

其中:1/2/2小于3,4/5大于3,而且输入的前后顺序也是1/2/2,4/5

一面刚开始是分布式存储团队,主要技术栈是hadoop,hbase以及hive,后来感觉我对分布式计算感兴趣,面试官帮我转岗到实时计算组,接着二面。

二面

自我介绍

聊项目,项目中有哪些难点,解决了什么问题?

spark streaming集群如何做容灾处理。

spark checkpoint原理。

了解哪些海量数据去重的方法。

flink和spark的区别?

flink了解哪些,它的基本架构原理

如何设计一个多级缓存系统,需要考虑到哪些问题?

redis和zookeeper做分布式锁的区别,还有其他方式做分布式锁吗?

一道算法:给定一个栈,使用O(1)的时间复杂度计算栈中的最小元素。

了解哪些机器学习算法?做过相关项目吗?

团队间协作需要注意哪些问题?

如何后面让你做同样的一个系统,你会从之前的项目中吸取怎么样的经验。

三面

自我介绍

深挖项目。

如何理解大数据,它解决了什么问题。

在一个很大的m*n的数组中,每一行有序,每一列无序,如何求其topk。

进程之间如何通信。

操作系统页的概念,每一页的大小是多少,为什么是这么多。

一台机器可以建立的连接是否是无限的,影响它的因素有哪些?

TCP断开连接时的time_wait状态?

确定一个TCP连接的5元组。

还有什么向问我的嘛?

如何理解实时计算。

过了几天,问了下,说是没HC了,给我转分布式存储,不过需要重新面试,就没再继续面了。

滴滴(面试通过)

一面

自我介绍

介绍项目。

说说JVM gc算法,垃圾回收器。

聊下java并发包的一些常用工具类

聊spark源码。

有什么想问的。

二面

redis的工作模型。

redis如何处理过期数据。

redis中hash类型求数据大小快还是将所有数据读出来快。

数据库与缓存读写一致性问题。

如果以上问题回答的不太完美,你会怎么办。

spark的通信模型,集群发生故障是怎么办。

spark的执行流程。

java中有哪些锁。

synchronized为什么是重量级锁。

如果工作中提出不合理的需求你会怎么办。

怎么看待加班。

实习时间。

过了几天面试官说面试通过,过几天老板会和我商量入职时间,然后过了几天。。。。HC被锁了。。

蘑菇街(offer)

一面

项目介绍,项目中的难点与亮点

spark sql的UDF,UDAF函数的实现。

Hive中如何实现UDF。

hashmap源码中有哪些成员变量,什么时候适合增大负载因子,什么时候适合减小。

java中float类型,类型转换。

字符串的匹配。

二面

自我介绍

java中有哪些锁

java CAS,看过native方法源码没有

什么是死锁,代码中出现了死锁怎么解决。

求一颗二叉树中topk大的元素。

java volatile关键字。

spark执行流程。

如何解决数据倾斜。

实习时间,倾向的岗位。

三面

你有哪些优势

大学期间对你影响最大的人

你有哪些优点和缺点。

对前面的面试自我感觉怎么样。

期望薪资

实习时间。

最终拿到offer。

总结:菜是原罪!!!鲁迅先生说:无论什么事,如果不断收集材料,积之十年,总可成一学者!日常积累和沉淀非常重要!

喜欢文章记得点个赞,感谢支持!

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 一篇文章看清楚JDK13的特性!

    提高应用程序类 - 数据共享(AppCDS)的可用性。消除了用户进行试运行以创建每个应用程序的类列表的需要。

    程序员追风
  • 2019年一线大厂最全JVM面试100问!你能答对多少?

    JVM(Java虚拟机)简单来说就是运行Java代码的解释器,作为螺丝钉程序员JVM其实了解下就差不多啦,不懂JVM内部细节照样能写出优质的代码!但是一到造火箭...

    程序员追风
  • 精心整理了15道面试官喜欢问的MyBatis面试题

    答:MyBatis 的缓存分为一级缓存和二级缓存,一级缓存放在 session 里面,默认就有,二级缓

    程序员追风
  • Java 8 开发的 4 大顶级技巧

    我使用Java 8编码已经有些年头,既用于新的应用程序,也用来迁移现有的应用,感觉是时候写一些我发现的非常有用的“最佳实践”。我个人并不喜欢“最佳实践”这个说法...

    芋道源码
  • java IO(File类、字节流与字符流、字节字符转换流)

    在整个io包中,唯一表示与文件本身有关的类就是File类。使用File类可以进行创建或删除文件等常用操作,要想使用File类,则首先要观察File类的构造方法...

    qubianzhong
  • Java基础-25(01)图形用户界面编程GUI

    1:如何让Netbeans的东西Eclipse能访问。 在Eclipse中创建项目,把Netbeans项目的src下的东西给拿过来即可。 注意:修改项目编码...

    奋斗蒙
  • 大数据技术之_19_Spark学习_01_Spark 基础解析 + Spark 概述 + Spark 集群安装 + 执行 Spark 程序

      Spark 是一种快速、通用、可扩展的大数据分析引擎,2009 年诞生于加州大学伯克利分校 AMPLab,2010 年开源,2013 年 6 月成为 Ap...

    黑泽君
  • mysql学习笔记(七)事务&批处理和JDBC的使用爬坑

    一个事务执行多个操作时,要么所有事务被提交,对数据库的操作成功。要么中途出现问题或者反悔回滚

    逆回十六夜
  • Android十八章:设计模式SOLID五大原则

    单一职责原则就是造成一个类改变的原因一个只有一个。再比如手机的电池是一个类,电池只为手机提供电源的职责。

    ppjun
  • Java 多线程协调工具 CyclicBarrier 与CountDownLatch 学习

    CyclicBarrier import java.util.concurrent.BrokenBarrierException; import java.ut...

    wannshan

扫码关注云+社区

领取腾讯云代金券