一面问题:MySQL+Redis+Kafka+线程+算法
- mysql知道哪些存储引擎,它们的区别
- mysql索引在什么情况下会失效
- mysql在项目中的优化场景,慢查询解决等
- mysql有什么索引,索引模型是什么
- B-树与B+树的区别?为什么不用红黑树
- mysql主从同步怎么做
- 乐观锁与悲观锁的区别?
- binlog日志
- redis 持久化有哪几种方式,怎么选?
- redis 主从同步是怎样的过程?
- redis 的 zset 怎么实现的?
- redis key 的过期策略
- hashmap 是怎样实现的?为什么要用红黑树,而不用平衡二叉树?为什么在1.8中链表大于8时会转红黑树?HashMap为什么线程不安全的?
- 如何实现线程安全的hashmap?
- select 和 epoll的区别
- http与https的区别,加密怎么加的?
- raft算法详细讲解
- Kafka 选主怎么做的?
- kafka如何保证生产与消费都是同步的?
- kafka 怎么保证不丢消息的
- redis如何保证高可用
- 算法:剪绳子(贪心或递归解决)
- 算法:给前序和中序遍历,重建二叉树
二面(volatile+线程+并发+算法+设计模式)
- 自我介绍
- 讲讲项目(项目没啥亮点,直接问基础)
- volatile作用?底层实现?禁止重排序的场景?单例模式中volatile的作用?
- 如何构造线程池,它的参数,饱和策略?
- 公平锁和非公平锁区别?为什么公平锁效率低?
- 线程都有哪些状态?
- 线程、进程、协程的区别?
- 同步队列器AQS思想,以及基于AQS实现的lock,。
- 并发工具类CountDownLatch、CyclicBarrier、Semaphore介绍
- Execuors类实现的几种线程池类型,最后如何返回?
- 手写单例模式
- 手写消费者生产者模式
- 算法