网站首页 > java教程 正文
一、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-30 应届生/社招面试最爱问的几道Java基础问题
- 2025-06-30 Spring整合CXF 发布webservice接口服务器和客户端,WSDL简单解析
- 2025-06-30 【深入 JavaEE】Spring AOP 注解实战全解析
- 2025-06-30 如何深度理解mybatis?(如何深度理解王阳明这个人的形象)
- 2025-06-30 Springboot中的javaConfig详解(基于Spring5.2)
- 2025-06-30 Spring IoC Container 原理解析(spring ioc基本原理)
- 2025-06-30 MyBatis映射文件深入解析(Mapper.xml)
- 2025-06-30 Java七大热门技术框架源码解析(完结)
- 2025-06-30 阿里资深架构师整理分享内部绝密MyBatis源码深度解析文档
- 2025-06-30 基于XML链式结构的研究(基于xml链式结构的研究现状)
你 发表评论:
欢迎- 08-03JVM内存结构和Java内存模型
- 08-03C++ 知识小结
- 08-03Java内存模型(JMM)详解
- 08-03为什么计算机内存需要堆和栈?
- 08-03Java中,对象一定在堆中分配吗?
- 08-03看完这篇,还不懂JAVA内存模型(JMM)算我输
- 08-03别再混淆了!JVM内存模型和Java内存模型的本质区别
- 08-03【C语言】(13)堆和栈
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)