【Java】Java核心关键字:final、static、volatile、synchronized、transient(附《面试高频考点》)
文章目录Java 5大核心关键字5大关键字——对比表1. final 关键字定义作用使用场景实现原理注意事项2. static 关键字定义作用使用场景实现原理注意事项3. volatile 关键字定义作用使用场景实现原理注意事项4. synchronized 关键字定义作用使用场景实现原理注意事项5. transient 关键字定义作用使用场景实现原理注意事项面试高频考点一、单个关键字 分阶高频考点1. final 关键字【基础必考题初中级100%覆盖】【进阶深挖题中高级高频】【高频坑点题】2. static 关键字【基础必考题初中级100%覆盖】【进阶深挖题中高级高频】【高频坑点题】3. volatile 关键字【基础必考题并发面试100%覆盖】【进阶深挖题中高级/大厂必问】【高频坑点题】4. synchronized 关键字【基础必考题并发面试100%覆盖】【进阶深挖题中高级/大厂必问】【高频坑点题】5. transient 关键字【基础必考题初中级高频】【进阶深挖题中高频】【高频坑点题】二、跨关键字 综合对比高频题面试必问拉分题三、场景手撕与实战题面试高频手写原理讲解四、大厂加分深挖题资深开发/高频Java 5大核心关键字5大关键字——对比表关键字核心作用多线程相关序列化相关主要场景final限制可变性类、方法、变量间接保证可见性❌常量、不可变类、安全设计static类成员共享变量、方法等❌❌工具类、全局变量、类初始化volatile可见性、禁止重排序✅❌状态标记、DCL 单例synchronized原子性、可见性、有序性✅❌临界区同步、复合操作保护transient跳过变量序列化❌✅敏感数据、临时缓存、不可序列化字段1. final 关键字定义final用于限制类、方法或变量的可变性表示“最终的、不可改变的”。作用修饰类该类不可被继承如String、Math类。修饰方法该方法不可被子类重写。修饰变量基本类型变量值不可修改。引用类型变量指向的对象地址不可修改但对象内部状态可改变。使用场景定义常量如public static final double PI 3.14。防止类被继承或方法被重写确保设计安全性。方法参数使用final避免参数被意外修改。实现原理编译期final变量会被编译器优化为“常量折叠”直接替换值。运行期JVM 会禁止对final变量的二次赋值并通过内存屏障确保final变量在构造函数中初始化后才被其他线程可见。注意事项final变量必须显式初始化声明时、构造器或代码块中否则编译报错。引用类型的final仅限制引用地址不限制对象内部状态需结合其他机制保证不可变。2. static 关键字定义static表示“静态的”用于修饰类成员变量、方法、代码块、内部类使其属于类而非实例。作用修饰变量静态变量类变量被所有实例共享内存中仅存一份。修饰方法静态方法可直接通过类名调用无需创建实例。修饰代码块静态代码块在类加载时执行一次用于初始化类资源。修饰内部类静态内部类不依赖外部类实例可直接创建。使用场景定义全局共享变量如计数器、配置常量。工具类方法如Math.random()、Collections.sort()。类初始化操作如加载驱动、读取配置文件。实现原理静态变量存储在方法区JDK 8 后为元空间随类加载而创建类卸载而销毁。静态方法在字节码层面通过invokestatic指令调用不依赖this引用。注意事项静态方法不能直接访问实例变量或实例方法无this引用但实例方法可访问静态成员。静态代码块仅执行一次且按定义顺序执行。3. volatile 关键字定义volatile是多线程同步关键字用于保证变量的可见性和禁止指令重排序但不保证原子性。作用可见性一个线程修改了volatile变量其他线程能立即看到最新值避免变量被缓存在寄存器或本地内存中。禁止重排序通过内存屏障禁止编译器和 CPU 对指令进行重排序确保执行顺序与代码逻辑一致。使用场景状态标记如boolean isRunning true;用于线程停止标记。双重检查锁定DCL实现单例模式防止指令重排序导致的空指针异常。实现原理可见性通过缓存一致性协议如 MESI变量修改后立即刷新到主内存其他线程嗅探到变化后失效本地缓存。禁止重排序在变量读写前后插入内存屏障如 LoadLoad、StoreStore 屏障限制指令重排范围。注意事项volatile不能替代synchronized因为它不保证原子性如count这类复合操作仍需锁。仅适用于“一个线程写、多个线程读”的场景多线程写需额外同步。4. synchronized 关键字定义synchronized是 Java 中最常用的同步机制用于保证多线程环境下的原子性、可见性和有序性。作用原子性确保被修饰的方法或代码块同一时间只能被一个线程执行。可见性线程释放锁前会将变量修改刷新到主内存获取锁后会从主内存读取最新值。有序性通过锁的“排他性”保证代码执行的有序性禁止临界区内的重排序。使用场景保护共享变量的复合操作如count、转账操作。同步方法或代码块确保多线程安全访问临界资源。实现原理对象头与 Mark Word每个对象的对象头中存储锁状态无锁、偏向锁、轻量级锁、重量级锁。monitorenter/monitorexit 指令编译后同步代码块会插入这两个指令用于获取和释放对象的监视器Monitor。锁升级机制JDK 6 后引入锁升级偏向锁→轻量级锁→重量级锁减少锁竞争带来的性能开销。注意事项锁的是对象而非代码实例方法锁this静态方法锁类对象Class代码块锁指定对象。避免锁粒度太大影响性能或太小导致线程安全问题。支持可重入性同一个线程可多次获取同一把锁避免死锁。5. transient 关键字定义transient用于修饰变量表示该变量不需要被序列化Java 序列化机制会忽略transient变量。作用跳过敏感数据或临时数据的序列化如密码、缓存计算结果。减少序列化后的文件大小提升性能。使用场景缓存字段如临时计算的中间结果反序列化后可重新计算。敏感信息如用户密码避免序列化后泄露。不可序列化的字段如Thread、InputStream需标记为transient避免报错。实现原理Java 序列化时ObjectOutputStream会检查字段是否被transient修饰若是则跳过该字段的写入。反序列化时transient变量会被初始化为默认值引用类型为null基本类型为0/false。注意事项static变量天然不参与序列化属于类状态非对象状态无需加transient。若需手动控制transient变量的序列化可实现Externalizable接口重写writeExternal()和readExternal()方法。面试高频考点一、单个关键字 分阶高频考点1. final 关键字【基础必考题初中级100%覆盖】简述final关键字的核心作用分别说明修饰类、方法、变量时的语义final修饰基本类型变量和引用类型变量的核心区别为什么String类要被定义为finalfinal和abstract能否一起使用为什么匿名内部类访问外部局部变量为什么变量必须加finalJDK8后为什么不用显式声明了【进阶深挖题中高级高频】final如何保证多线程下的可见性和volatile的可见性实现有什么区别什么是不可变类如何基于final实现一个线程安全的不可变类final的编译期优化常量折叠是什么有哪些限制条件final方法能不能被重载和重写的核心区别是什么JVM对final字段有哪些重排序规则为什么要禁止final字段在构造函数初始化完成前发生对象逸出【高频坑点题】final修饰的集合对象能不能添加/删除元素为什么被final修饰的变量一定是编译期常量吗final修饰的实例方法子类中能不能定义同名同参数的方法2. static 关键字【基础必考题初中级100%覆盖】简述static关键字的核心作用分别说明修饰变量、方法、代码块、内部类的语义静态变量和实例变量的核心区别存储位置有什么不同静态方法能不能直接访问实例成员变量/方法为什么静态代码块、构造代码块、构造方法的执行顺序是什么父子类场景下的完整执行顺序静态内部类和非静态内部类的核心区别【进阶深挖题中高级高频】static成员的生命周期类加载的哪个阶段会初始化静态变量和静态代码块静态方法能不能被重写为什么结合多态动态绑定机制说明静态变量存在线程安全问题吗什么场景下会触发static和final组合使用的核心场景public static final定义常量的规范与注意事项类加载过程中静态变量的初始化和静态代码块的执行顺序由什么决定【高频坑点题】能不能在构造方法中给静态变量赋值static代码块能不能捕获异常静态方法用synchronized修饰时锁的对象是什么和实例同步方法有什么区别3. volatile 关键字【基础必考题并发面试100%覆盖】volatile关键字的两个核心作用是什么什么是指令重排序volatile如何禁止指令重排序什么是内存可见性volatile如何保证变量的可见性volatile能不能保证原子性为什么举一个典型反例volatile和synchronized的核心区别【进阶深挖题中高级/大厂必问】双重检查锁定DCL实现单例模式为什么必须加volatilevolatile的内存屏障机制是什么读/写操作前后分别插入什么类型的内存屏障volatile对应的happens-before规则是什么MESI缓存一致性协议和volatile的关系volatile在JDK源码中的经典应用AtomicInteger、ConcurrentHashMap、ThreadPoolExecutor等什么是伪共享volatile和伪共享的关系如何解决伪共享问题【高频坑点题】加了volatile的count操作是线程安全的吗volatile修饰long/double类型变量在32位JVM上读写是原子的吗volatile和final能不能一起使用4. synchronized 关键字【基础必考题并发面试100%覆盖】synchronized的三种使用方式分别锁定的是什么对象synchronized如何保证原子性、可见性、有序性什么是锁的可重入性synchronized是可重入锁吗底层如何实现一个线程调用对象的synchronized实例方法时另一个线程能否调用同一个对象的非synchronized方法synchronized和Lock接口的核心区别【进阶深挖题中高级/大厂必问】详细说明synchronized的锁升级全流程偏向锁→轻量级锁→重量级锁包括每种锁的适用场景、升级触发条件、优缺点Java对象头的结构是什么Mark Word在不同锁状态下分别存储什么内容synchronized的底层实现原理monitorenter/monitorexit指令、Monitor监视器机制JDK6对synchronized做了哪些性能优化自适应自旋、锁消除、锁粗化、偏向锁、轻量级锁重量级锁的底层实现为什么说重量级锁的性能开销大synchronized的锁释放时机有哪些方法抛出异常时会不会释放锁【高频坑点题】两个线程分别调用同一个类的synchronized静态方法和synchronized实例方法会不会发生互斥为什么父类synchronized修饰的方法子类重写后默认还是同步方法吗自旋锁一定比重量级锁效率高吗能不能在try块中加synchronized在finally里手动释放锁5. transient 关键字【基础必考题初中级高频】transient关键字的核心作用是什么哪些场景下需要使用transient关键字被transient修饰的变量反序列化后的默认值是什么【进阶深挖题中高频】被transient修饰的变量真的完全不能被序列化吗有没有例外情况ArrayList的elementData数组为什么要被transient修饰static变量会被序列化吗加了transient的static变量呢自定义序列化的方式有哪些如何手动控制transient变量的序列化与反序列化Externalizable和Serializable接口的区别对transient关键字的处理有什么不同【高频坑点题】transient修饰的final变量能不能被序列化静态内部类的transient变量序列化有什么限制二、跨关键字 综合对比高频题面试必问拉分题从原子性、可见性、有序性、性能、使用场景等维度对比volatile和synchronized的核心区别final和static的核心区别二者组合使用的场景与注意事项synchronized和volatile的有序性保证底层实现有什么区别transient和static的核心区别为什么static变量天然不参与序列化final、volatile、synchronized在保证多线程可见性上的区别与实现原理同时使用static和synchronized和普通实例synchronized方法有什么本质区别三、场景手撕与实战题面试高频手写原理讲解手写双重检查锁定DCL单例模式解释每一步的作用尤其是volatile的核心作用基于final关键字手写一个线程安全的不可变类写出父子类场景下静态代码块、构造代码块、构造方法的完整执行顺序代码并解释执行逻辑手写自定义序列化示例手动控制transient变量的序列化与反序列化写出volatile的正确使用场景示例、错误使用场景示例并解释背后的原因四、大厂加分深挖题资深开发/高频详细讲解volatile的内存屏障在x86架构下的具体实现synchronized的锁撤销、锁降级机制的适用场景与实现原理JSR-133内存模型中对final字段的重排序规则做了哪些规范为什么说synchronized是不公平锁有没有办法实现公平的synchronizedJDK8前后静态变量的存储位置发生了什么变化对static关键字的使用有什么影响序列化机制中transient关键字和serialVersionUID有什么关联
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2448764.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!