第一轮提问
面试官:小旭,说说Java中的HashMap如何处理哈希冲突?
范小旭:使用链地址法,当哈希值相同的时候,会把节点挂到链表上。
面试官:很好,那JVM内存模型分为哪几个区域?
范小旭:方法区、堆、栈、程序计数器...
面试官:不错,那线程池的核心线程数和最大线程数有什么区别?
范小旭:核心线程数是保持存活的线程数,最大线程数是能扩展到的最大数量。
第二轮提问
面试官:Spring的Bean生命周期有哪些关键阶段?
范小旭:实例化、属性赋值、初始化...
面试官:MyBatis如何防止SQL注入?
范小旭:使用预编译和参数化查询,比如#{}占位符。
面试官:Redis的持久化机制有哪些?
范小旭:RDB和AOF,RDB是快照,AOF是日志...
第三轮提问
面试官:说说Dubbo的负载均衡策略?
范小旭:随机、轮询、最少活跃数...
面试官:Linux如何查看进程占用的内存?
范小旭:用top命令,或者ps -ef...
面试官:最后,你有什么想问的吗?
范小旭:...
面试官总结
面试官:今天就到这里,回去等通知吧。
答案详解
- HashMap通过链地址法+红黑树处理哈希冲突,当链表长度超过8时转为红黑树
- JVM内存包括方法区、堆、虚拟机栈、本地方法栈、程序计数器
- 线程池核心线程数是保持存活的线程数,最大线程数是允许创建的最大线程数
- Spring Bean生命周期:实例化→属性注入→Aware接口回调→初始化方法→使用→销毁方法
- MyBatis通过#{}占位符实现预编译,防止SQL注入
- Redis持久化采用RDB快照和AOF日志两种方式
- Dubbo负载均衡策略包括随机、轮询、最少活跃数、一致性哈希等
- Linux查看内存使用:top命令实时监控,ps -ef查看进程详情

被折叠的 条评论
为什么被折叠?



