https://leetcode-cn.com/circle/discuss/aX6VxT/

lamda源码,乐观锁ABA问题,红黑树,平衡二叉树,b和b加树 tomcat启动容量,初始化 solr如何实现,基于什么,如何解决id冲突权重 websocket心跳 讲讲对nosql的理解 nosql怎么保持关联 hashmap初始大小 怎么设置 还有stomp和websocket的关系
es的基本操作 treemap自定义排序 mongodb和es的区别 dubbo原理 maven热部署,常用命令maven打包如何解决循环依赖本地仓库,中央仓库如何配置 mynatis和hi bernate区别
cookie大小,一个站可以存放多少cookie 反射和泛型有没有使用到 git

bitmap
https://baijiahao.baidu.com/s?id=1632565702014272316&wfr=spider&for=pc

image.png
image.png

总结起来:面试官喜欢抛出一个大点,看你能讲多广多深
一面: 90mins
讲项目
讲一个集合框架整体框架

锁的分类
乐观锁、悲观锁、自旋锁、读写锁、(排它锁、共享锁、)分段锁等等各自特点,以及它们在java中具体的实现方式
Spring IOC的底层实现
XML+dom4j+工厂+单例

二面:40mins
讲项目


18.CachedThreadPool里面用的什么阻塞队列
SynchronousQueue

Spring AOP的底层实现
动态代理,newProxyInstance,cglib,ASM
讲一下代理模式
动态代理,静态代理
你都了解什么设计模式,他们在JDK中如何体现的
工厂,责任链,观察者,建造,代理,单例,原型等等在JDK中对应的体现。。。
三面coding:2h
,抢红包
四面:50mins
讲项目
讲一下JVM堆内存管理
栈上分配->TLAB->新声代、老年代->可达性分析->GC算法->所有垃圾回收器及其优缺点和特点
那到底多大的对象会被直接扔到老年代
G1两个region不是连续的,而且之间还有可达的引用,我现在要回收其中一个,另一个会被怎么处理
听说过CMS的并发预处理和并发可中断预处理吗

平常怎么学习的和职业规划
五面coding:2h
百万级int数据量的一个array求和(fork/join)



22.你知道新出的LongAdder吗,和AtomicLong有什么区别
AtomicLong相当于多线程竞争一次修改value的机会
LongAdder把value拆成多个值放在cell数组里,相当于多线程竞争多次修改value的机会,性能自然上升

23.那你知道LongAccumulator吗
不仅支持加法,还支持自定义的其他操作

3.CMS和G1的异同

4.G1什么时候引发Full GC


7.允许null键的map你知道哪些
HashMap,LinkedHashMap,WeakHashMap

8.null键放在HashMap的哪里
底层数组的0号位置

9.为什么hashtable的扩容是2倍+1
从除留余数法,hashtable初始容量方面回答

10.红黑树的插入时间复杂度

11.解决哈希冲突的方式

12.现有1T的数据,内存只有1G,该怎么对他们排序
外部排序(多路归并)

13.Tomcat为什么要重写类加载器

14.tcp握手挥手过程及其状态转换

15.mysql隔离级别

16.B树和B+树的区别

17.你知道哪些设计模式,它们在JDK源码中是怎么体现的

18.Java运行时数据区

19.说一个最熟悉的垃圾回收算法

20.吞吐量优先和响应时间优先的回收器是哪些
parallel scavenge和CMS

21.类加载全过程


24.Java内存模型
JMM共享内存模型以及8个原子操作指令

26.cookie和session介绍一下

27.说一下反射,反射会影响性能吗

28.谈一下AQS吧

29.

30.JUC包里的同步组件主要实现了AQS的哪些主要方法
tryAcquire, tryRelease, tryAcquireShared, tryReleaseShared, isHeldExclusively
coding:leetcode+剑指offer原题共5题
美团(3轮技术面):

1.ConcurrentHashMap底层原理

2.手写一个LRU
用LinkedHashMap

3.HashMap底层数据结构

4.为什么用红黑树不用普通的AVL树

5.为什么在8的时候链表变成树

6.为什么在6的时候从树退回链表


11.PriorityQueue底层是什么,初始容量是多少,扩容方式呢
最小堆,
11,若原始大小<64,则扩容为原来的2倍+2,不然就扩容为原来的1.5倍

12.HashMap的容量为什么要设置为2的次幂

13.你知道跳表吗,什么场景会用到
ConcurrentSkipListMap,用在多线程下需要自定义排序顺序时

14.CopyOnWriteArrayList知道吗,迭代器支持fail-fast吗
线程安全ArrayList,写时复制,迭代器是采用快照风格,不支持fail-fast

15.innodb的底层数据结构

16.为什么用B+树不用B树

17.为什么用B+树不用红黑树

18.coding:无序数组怎么寻找第k大的数,写一个二叉树层次遍历

19.不知道大小的数据流取其中100个数,怎样的取法能最随机

20.n个物品每个物品都有一定价值,分给2个人,怎么分两个人的价值差最小

21.假设百度每个页面能放100个网页,每个页面都有一个评分,怎样快速找到第8页的所有网页
顺丰(2轮技术面):

2.说说你了解什么设计模式,知道责任链设计模式吗

3.wait/notify体现了什么设计模式

5.谈一下spring事务传播

6.谈一下IOC底层原理

7.怎么判断内存泄漏

8.怎么在日志里排查错误,该用哪些Linux命令

9.mysql原子性和持久性怎么保证
undolog,redolog

10.怎么解决幻读
MVCC+间隙锁

11.innodb和myisam区别

13.对象的创建过程

14.对象在内存中的存储布局
对象头,类元指针,实例数据,对齐填充

15.对象头具体包括什么

16.对象怎么定位
直接指针,句柄

17.堆的划分

18.对象怎么分配
栈上分配->TLAB->老年代->新生代

19.具体讲一下CMS流程

20.锁的四种状态

21.Object obj = new Object()这句话在内存里占用了多少内存
引用变量4Byte,Object对象的对象头12Byte,由于对齐填充增值16Byte,共20Byte


1.总体说一下集合框架

2.你怎么看待接口和抽象类


5.设计模式说5,6个

6.谈一谈DDD面向领域编程


8.说一下你了解的MQ

9.谈一谈你对高并发的理解,你会从什么角度设计高并发程序

10.JUC包里的限流该怎么做到
Semaphore / guava ratelimiter

12.说一下NIO和AIO

13.AIO里用到什么设计模式
观察者

14.说一下select,poll,epoll

15.谈一下TCP的拥塞控制

16.你知道什么是as-if-serial语义吗,它和happen-before语义有什么区别
本质没啥区别,前者是谈的单线程程序,后者谈的多线程程序