前言

本篇题材来自我朋友的朋友,他在最近的社招中拿到美团的Offer,整体思路和面试题目由面试本人提供

由于作者面试过程中高度紧张,本文中只列出了自己还记得的部分题目。

一面:

  • 自我介绍
  • HashMap,ConcurrentHashMap与LinkedHashMap的区别
  • 如何在多线程环境下使用Map,ConcurrentHashMap原理,ConcurrentHashMap如何加锁。
  • 多线程并发的同步实现,有两个方法,每个方法里有a部分代码和b部分代码,我要让两个线程分别执行两个方法,并且让他们运行完a部分代码再一起向下执行,如何实现。
  • TCP连接中的三次握手和四次挥手,四次挥手的最后一个ack的作用是什么,为什么要time wait,为什么是2msl。
  • ReetrantLock和synchronized的区别。
  • Java有哪些悲观锁的实现?
  • Java有哪些类实现了乐观锁?
  • java里面的同步锁了解吗?Countdownlauch和Cylicbarrior的区别,分别在什么应用场景下使用
  • JVM的内存结构?哪些是共享的,哪些是线程私有的?Java虚拟机栈里面存放的是什么?
  • 如何自己实现一个线程池让别人使用?
  • 哪些情况会触发Java的类加载?
  • 手写代码:快速排序、单例模式,化一个工厂和装饰者模式的UML类图
  • AOP的实现原理?
  • Java锁有哪几种?可重入锁和不可重入锁的区别?
  • Lock和synchronized的区别?它们都是可重入锁吗?哪个效率更高?

二面:

  • 线程池有哪些参数?分别有什么用?如果任务数超过的核心线程数,会发生什么?阻塞队列大小是多少?
  • 数据库连接池介绍下,底层实现说下
  • hashset底层实现,hashmap的put操作过程
  • 说说HaspMap底层原理?再说说它跟HaspTable和ConcurrentHashMap他们之间的相同点和不同点?
  • 说说B+树和B树的区别,优缺点等?
  • 算法题,对一个链表进行归并排序,链表可能有环
  • 怎么实现一个线程安全的计数器?
  • 原子类AtomicInteger实现原理是什么?和你设计的计数器优劣比较?CAS怎么实现原子操作的?
  • Java中的锁有什么?synchronized与Lock的区别?公平锁和非公平底层怎么实现的?AQS原理详细介绍一下?
  • JVM中的内存区域划分,堆的分代,为什么分代, 垃圾回收算法,垃圾回收器
  • 如何实现进程间特定场景下的高效通信, 问了存储相关的问题。
  • MySQL索引类型, 底层的数据结构
  • 你了解哪些收集器?CMS和G1。详细谈谈G1的优点

三面:

  • 自己项目中的总结的并发经验
  • 说说MySQL的锁并发?加锁的机制是什么?
  • 高并发场景下如何防止死锁,保证数据的一致性?
  • 集群和负载均衡的算法与实现?
  • 说说分库与分表设计?
  • 分库分表带来的分布式困境与对应之策有哪些?
  • Redis和Setnx命令是如何实现分布式锁的?使用Redis怎么进行异步队列?会有什么缺点?
  • 缓存击穿的概念和解决方案?
  • Redis的数据结构? 线程模型? Redis的数据淘汰机制?
  • Redis的数据一致性问题
  • MQ底层原理的实现?
  • 阻塞队列不用Java提供的该怎么实现?
  • 讲讲负载均衡的原理?
  • 如何实现高并发环境下的削峰、限流?

HR面(略)

总结

面试建议是,一定要自信,敢于表达,面试的时候我们对知识的掌握有时候很难面面俱到,把自己的思路说出来,而不是直接告诉面试官自己不懂,这也是可以加分的。

备战面试,刷题是必不可少的。小编这里也是拿到这位朋友备战面试的资料,其中包括一些面试题和视频 可以提供给需要的朋友参考。点赞关注后,私信我【资料】即可(一定要记得关注我,不然没办法回复陌生人私信)