网站首页 > 博客文章 正文
一、JVM与内存管理(高频考点)
- 1. 内存结构
JVM内存分为堆、方法区、虚拟机栈、本地方法栈和程序计数器。堆是对象存储的核心区域,分为新生代(Eden、Survivor区)和老年代。
o 示例:new Person()会在堆中分配内存,而局部变量int age=25则存储在虚拟机栈中。
o 调优技巧:通过-Xmx设置最大堆内存,避免OOM(内存溢出)。 - 2. 垃圾回收(GC)机制
o 算法类型:标记-清除(内存碎片多)、复制算法(适合新生代)、标记-整理(老年代优化)。
o 实战问题:如何排查内存泄漏?可通过jmap导出堆内存快照,用MAT工具分析对象引用链。 - 3. 类加载机制
双亲委派模型防止核心类被篡改(如自定义String类无效)。类加载流程:加载→验证→准备→解析→初始化。
二、并发编程(面试必问)
- 1. 线程池核心参数
new ThreadPoolExecutor(2,4,60,TimeUnit.SECONDS,new ArrayBlockingQueue<>(100));
o 参数解析:核心线程数(2)、最大线程数(4)、空闲存活时间(60秒)、任务队列(容量100)。
o 避坑指南:队列满时触发拒绝策略,需根据业务选择AbortPolicy或CallerRunsPolicy。
- 2. 锁机制对比
o synchronized:JVM内置锁,自动释放,但灵活性差。
o ReentrantLock:支持尝试获取锁、超时机制,需手动释放。
o 场景选择:简单同步用synchronized,复杂场景(如公平锁)选ReentrantLock。 - 3. 线程安全实践
o volatile:保证可见性,适合状态标志(如boolean isRunning)。
o CAS原子操作:通过AtomicInteger实现无锁计数,避免阻塞。
三、Spring框架原理(架构核心)
- 1. IoC容器
Spring通过XML或注解(如@Bean)管理对象生命周期,实现依赖注入。
o 示例
@Configuration
public class AppConfig {
@Bean
public UserService userService() {
return new UserServiceImpl(userDao());
}
}
- 2. AOP实现原理
使用动态代理(JDK Proxy或CGLIB)实现日志、事务等横切逻辑。
o 切面示例
@Around("execution(* com.example.service.*.*(..))")
public Object logMethod(ProceedingJoinPoint joinPoint) throws Throwable {
System.out.println("方法开始执行");
return joinPoint.proceed();
}
- 3. 事务管理
o 传播行为:REQUIRED(默认,加入当前事务)、REQUIRES_NEW(新建事务)。
o 隔离级别:读已提交(避免脏读)、可重复读(MySQL默认)。
四、分布式系统设计(进阶难点)
- 1. 分布式事务解决方案
o 2PC:两阶段提交,强一致性但存在单点故障风险。
o TCC:Try-Confirm-Cancel,适合高并发场景(如电商扣库存)。 - 2. 高并发设计
o 限流:令牌桶算法(Guava RateLimiter)。
o 缓存:Redis缓存热点数据,降低数据库压力。
o 消息队列:Kafka异步处理订单,避免系统过载。 - 3. 微服务架构
o 服务注册与发现:Nacos或Eureka管理服务节点。
o 熔断降级:Hystrix或Sentinel防止服务雪崩。
五、数据库与性能优化(实战重点)
- 1. 索引优化
o B+树索引:适合范围查询,InnoDB聚簇索引按主键排序。
o 覆盖索引:查询字段全部在索引中,避免回表(如SELECT id,name FROM user)。 - 2. 分库分表策略
o 水平分表:按用户ID哈希分片,均匀分布数据。
o ShardingSphere:支持读写分离、柔性事务。 - 3. SQL调优
o 执行计划分析:EXPLAIN查看索引使用情况。
o 慢查询日志:定位执行时间超过阈值的SQL。
六、设计模式(代码质量保障)
- 1. 单例模式
o 双重检查锁
public class Singleton {
private static volatile Singleton instance;
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
- 2. 工厂模式
通过工厂类解耦对象创建(如Spring的BeanFactory)。
七、项目经验与系统设计(面试加分项)
- 1. 项目描述技巧
使用STAR法则:背景(Situation)→任务(Task)→行动(Action)→结果(Result)。
o 示例:“主导某电商秒杀系统,通过Redis预减库存+MQ异步下单,QPS从500提升至5000”。 - 2. 系统设计考题
o 设计秒杀系统:分层校验(活动是否开始)、库存预热、限流降级。
o 技术难点:如何解决超卖?使用Redis分布式锁或数据库乐观锁。
猜你喜欢
- 2025-06-24 面试必备!Java核心技术面试100题(java核心面试精讲)
- 2025-06-24 2024最新版java面试题(八股文+场景题)合集!
- 2025-06-24 「开发者成长」5 个刁钻的Java String 面试题
- 2025-06-24 25 年 Java 开发者面试必问 TOP10 核心问题及破题攻略
- 2025-06-24 Java高薪跳槽面试官最爱问的50道题深度解读
- 2025-06-24 Java高频八股文面试题及参考答案(js 八股文)
- 2025-06-24 10 个经典的 Java 集合面试题,看你能否答得上来?
- 2025-06-24 Java面试场景题及答案最全总结(2025版持续更新)
- 2025-06-24 2025年阿里Java面试题库(纯干货,超详细,从题目到答案)
- 2025-06-24 Java面试题及答案最全总结(2025版持续更新)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)