小米面经 后台开发 二面

发面经攒人品~

首先自我介绍,介绍完就让我写一个单例模式,然后我写的双检锁,写完问为什么要两次判断==null,为什么要用volatile

然后说到了处理器指令重排、内存屏障,问处理器一般会怎么指令重排,是问重排序的三种:编译器优化的重排序、指令级并行的重排序和内存系统的重排序;

问synchronized底层实现,偏向锁、自旋锁、轻量级锁、重量级锁,能否从重量级到轻量级,synchronized加在类和方法上的区别;为什么是可重入的?不可中断解释一下。

final域修饰字段能保证线程安全?为什么?

list的线程安全集合知道哪些?CopyOnwriteAarryList说一下。

说出你知道的解决哈希冲突的所有方法,hashmap为什么用链地址法,链表>=8时转成红黑树,为什么用红黑树?那又小于8以后会变成链表吗?如果在6,7,8来回变会怎么样?

B、B+树的区别,Innodb的索引为什么用B+树,哈希索引和B+树索引作比较

死锁发生的原因,我就只说了互相占有且等待,问还有吗?写一个死锁程序。

提交一个任务到线程池,线程池怎么处理,你平时用现成的还是自定义重写线程池,newFixedThreadPool和newCacheThreadPool区别,饱和策略有哪些

然后问实习相关的内容,问遇到过什么问题,我说了一个Guava缓存、Redis和数据库结合使用的三级缓存,发生缓存雪崩,怎么解决的?

kafka,如果消费者端消费了一小段任务,突然挂掉了,然后服务端重新发消息让其他消费者执行,挂掉的消费者本来已经执行了一点任务,但是offset并不是在挂掉时候的那里,  然后让其他消费者执行,会重复执行,该怎么办?还有一些问题我忘了。

平常怎么学习技术?

后面就是闲聊,大概面了55分钟。

#小米##校招##面经##Java工程师#
全部评论
请问一面到二面中间有多久?
1 回复 分享
发布于 2019-09-19 14:59
好详细!😀
点赞 回复 分享
发布于 2019-09-19 15:07
好难啊
点赞 回复 分享
发布于 2019-09-19 15:21
我知道你的面试官,应该是个白白的微胖,头发挺多的戴眼镜
点赞 回复 分享
发布于 2019-09-19 22:22
HashMap红黑树节点少于8个后,会不会退化成链表😢
点赞 回复 分享
发布于 2019-09-21 09:39

相关推荐

10.25 一面:聊一下你的项目,约具体越好,可以将到实际写了哪些代码多线程调度是怎么实现的线程调度是怎么保护现场的线程调度是怎么恢复现场的为什么多线程修改同一个变量时需要加锁(单核处理器)为什么锁不会出现出现多线程不安全的情况PV操作是怎么实现的循环队列的特点是什么时钟中断是怎么实现的CPU如何获取中断后跳转到需要的中断处理函数中的场景题:现在有很多中断,每个中断的时间片不一样,但是只有一个中断的硬件设备,如何设置键盘中断是怎么实现的加分题:一个字符是怎么从内存中打印到显示屏上的struct和union的区别数组和链表的区别map的底层实现是什么红黑树有什么特点在数中如何最快查找某个元素知道图像的编码格式吗10.26 二面:内存管理是怎么实现的arena是怎么实现的如果有申请很多个10KB的内存块,后面想申请64KB的内存块怎么办内存块的释放是怎么实现的最先匹配和最佳匹配的优缺点最先匹配和最佳匹配的性能哪个更好分页讲一下页表里面存放哪些内容页中有哪些控制符哪些内容是只读的程序分为哪几段.bss段内存放哪些内容初始化和未初始化的局部变量分别存放在哪个段这几个段中哪个是只读的为什么代码段是只读的操作系统有哪些锁自旋锁的原理哪些情况下只能用自旋锁中断中可以用mutex吗零拷贝了解吗智能指针unique_ptr的原理shared_ptr的程序计数器为什么是线程安全的代码题:vec.resize(5), vec.push(100), 迭代器会失效吗手撕:1. PV操作2. 循环队列10.28 hr面
查看45道真题和解析
点赞 评论 收藏
分享
5 69 评论
分享
牛客网
牛客企业服务