-
Method对象不能直接newMethodHandle,因其为不可实例化的final类,必须通过MethodHandles.Lookup的revealDirect()还原为MethodHandle,再按需用reflectAs()适配类型。
-
必须用字符串构造BigInteger,因无BigInteger(long)构造方法;超大整数只能通过newBigInteger("str")初始化;算术运算需调用add、multiply等方法;比较用compareTo,转换用longValueExact;注意字符串输入需trim和校验。
-
代理模式通过代理对象为原对象提供额外功能。静态代理需手动编写代理类,编译期确定,每个目标类对应一个代理类,代码重复;动态代理在运行时生成代理类,JDK动态代理基于接口,通过Proxy和InvocationHandler实现,CGLIB基于继承,使用ASM生成子类,适用于无接口类。两者核心区别在于代理类生成时机与灵活性,动态代理更利于解耦和扩展。
-
Java支持引用类型返回值协变:子类重写方法可将返回类型替换为父类返回类型的子类,如Person→Student,但基本类型和void不支持;方法签名其余部分必须完全一致,配合多态可直接获得精确类型。
-
可在不破坏闭包语义前提下用函数式接口封装异常处理,须保持签名不变、不泄露实现、不改变成功路径预期;包裹器应继承原接口异常能力、避免new/this引用、通过组合式链式调用组装纯函数handler、显式隔离副作用、谨慎翻译异常、禁用阻塞操作,并与default方法协同分层扩展。
-
静态块不适合加载证书,因其在类加载时执行,无法确定文件路径、易因证书未部署而失败,且异常会导致类加载失败;应改用初始化流程如@PostConstruct或main方法加载。
-
Eden区是TLAB的母体而非后备,TLAB从Eden中划分,其稳定性依赖Eden足够大、结构健康;Eden过小会限制TLAB伸缩空间,导致频繁refill或fallback至共享区竞争分配。
-
企业级架构中对大对象创建实施熔断,本质是拦截对象实例化或数据加载行为本身,如反序列化超大JSON、构建巨型DTO等,防止OOM、GC频繁等问题。
-
Enum.valueOf严格匹配枚举常量名(区分大小写、不可含空格),需封装安全转换逻辑,如忽略大小写、trim空格、提供默认值或使用枚举内建fromString方法。
-
ThreadLocal不是线程私有变量的自动托管工具,而是以线程为维度的Map查找机制;真正隔离靠每个线程独立持有ThreadLocalMap实例,staticfinal声明仅共享ThreadLocal对象本身,各线程操作的是各自Thread.threadLocals中的值。
-
Java字符串常量池调优需根据实际intern字符串数量和冲突率合理设置-XX:StringTableSize,目标是平均桶长≤1.5,优先验证是否真需调整,避免盲目增大导致内存浪费。
-
硬编码魔法值在分支结构中危害严重,应通过语义化封装、规则外置化、策略模式和快照日志实现可配置、可审计的规则体系,并渐进式落地。
-
本文详解hasNextInt()的工作原理与典型误用场景,重点演示如何用它替代try-catch实现健壮的双整数输入验证,并给出可复用的循环输入处理方案。
-
Selector通过操作系统内核的I/O多路复用(如Linuxepoll)实现高效轮询,select()阻塞等待内核通知就绪Channel,仅处理selectedKeys()中的活跃事件,避免遍历全部Channel;注册前须设为非阻塞并指定interestOps;迭代selectedKeys()后必须手动remove();单Selector瓶颈在JVM内存、GC和业务逻辑耗时,应分离IO与业务处理。
-
应显式指定字符集避免乱码,因String.getBytes()无参时依赖平台默认编码(如Windows为GBK、Linux/macOS为UTF-8),导致跨环境字节数组不一致;推荐使用StandardCharsets.UTF_8等静态常量进行编码/解码。