-
static修饰的成员属于类而非实例,包括静态变量(所有对象共享)、静态方法(只能访问静态成员)、静态代码块(类加载时执行一次)和静态内部类(不依赖外部类实例)。
-
Class.forName()默认初始化类(执行static块),ClassLoader.loadClass()默认不初始化;Proxy要求接口因代理类已固定继承Proxy且Java不支持多重继承;CGLIB报错多因版本冲突或非必要使用。
-
自定义RuntimeException可明确表达业务错误,避免通用异常丢失上下文,如库存不足时抛出带商品信息的异常,提升代码可读性与系统健壮性。
-
本文深入探讨Java泛型中Optional<Sub>无法直接赋值给Optional<Super>的原因,即泛型的不变性。我们将解析Optional.map()方法如何通过其泛型签名和类型推断机制,巧妙地实现安全的类型转换。同时,文章还将介绍Java中利用通配符实现协变的方法,并分析Stream.map()与findFirst()组合时可能遇到的类型推断问题及解决方案。
-
使用ConcurrentHashMap与FutureTask可有效实现多线程安全缓存加载,通过putIfAbsent确保仅一个线程加载数据,其余等待共享结果,避免重复加载;GuavaCache提供更简洁方案,内置并发控制;双重检查加volatile适用于轻量场景。
-
Java四种引用类型:①强引用默认存在,GC绝不回收,易致内存泄漏;②软引用在内存不足时回收,适合缓存;③弱引用在GC时立即回收,用于WeakHashMap等临时绑定;④虚引用无法获取对象,仅用于回收通知,需配合ReferenceQueue。
-
Java异常体系以Throwable为根,分为Error(不捕获)和Exception;Exception又分RuntimeException(非受检,如NullPointerException)和受检异常(如IOException,必须声明或捕获)。
-
推荐继承RuntimeException,因其属非检查异常,避免强制处理、契合事务回滚、便于统一拦截;业务异常本质是逻辑错误而非系统故障,无需编译器强制捕获。
-
TreeMap基于红黑树实现,按键排序存储,支持自然排序和自定义Comparator排序,适用于需有序键值对的场景。
-
Java线程池有4种内置拒绝策略:1.AbortPolicy抛异常,适用于支付等关键业务;2.CallerRunsPolicy由调用线程执行,实现降速,适合非实时任务;3.DiscardPolicy静默丢弃,用于可丢失任务;4.DiscardOldestPolicy丢弃最老任务,适用于新数据价值更高的场景。
-
本文旨在解决IntelliJIDEA中新手常遇到的“nousage”提示问题,尤其是在main方法和其所属类上出现的误导性提示。文章将深入解释此提示的含义、为何在简单项目中出现,并提供详细的步骤指导,帮助用户通过IDE设置关闭这些不必要的提示,从而优化开发体验。
-
finally块用于确保关键代码始终执行,常用于资源释放、状态重置等场景;其典型应用包括关闭文件流、数据库连接,且需注意避免在其中抛出异常或使用return语句,否则可能掩盖异常或改变返回值;现代Java推荐优先使用try-with-resources替代手动资源管理,以提升代码安全性和可读性。
-
Java中包声明必须是源文件第一行非注释语句,且一个文件只能有一个package;import语句紧随其后,不能在类内部或方法里出现。
-
面向对象建模通过封装、继承、多态和抽象实现高内聚低耦合,提升可维护性的关键是合理划分对象边界与职责:遵循单一职责原则、依赖抽象而非实现、用策略模式+组合应对变化、以业务语义命名类与方法,并用值对象、枚举、聚合根等强化模型表达力。
-
读写锁通过分离读写操作提升并发性能。Java中ReentrantReadWriteLock允许多线程并发读,写时独占锁,适用于读多写少场景,如缓存和配置管理,需注意避免死锁与读饥饿问题。