-
Java封装的核心价值在于通过访问控制明确职责边界、约束外部行为、降低模块耦合;它以private字段保护内部状态,辅以带校验的getter/setter,实现数据隐藏、安全增强与接口实现分离,提升可靠性、可维护性与协作效率。
-
反射频繁调用会触发动态代理类生成并加载至元空间,若卸载不及时将导致元空间OOM;需通过jstat、jcmd、jmap等工具确认问题,定位高频反射点,禁用膨胀机制(-Dsun.reflect.noInflation=true)或改用MethodHandle/VarHandle优化。
-
this能解决变量名冲突,因为它明确指向当前对象的成员变量,避免被同名局部变量遮蔽;在构造函数中必须用this.name=name来正确赋值,否则会导致自赋值错误。
-
SpringBoot3废弃了spring.factories,必须改用META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports文件声明自动配置类,并推荐使用@AutoConfiguration替代@Configuration以保障加载顺序与条件化行为。
-
面向接口编程的核心是依赖抽象契约而非具体实现,关键在于明确角色职责、隔离变化、提升可替换性与可测试性,需回答“谁用它、能做什么、边界在哪”,避免假抽象和接口泛滥。
-
Integer.compare()本身稳定且符合自然序,但排序稳定性由比较器逻辑与Timsort算法共同保证;正确使用它构建比较器(如处理null时显式判断)可确保相等元素相对位置不变。
-
SIGNAL必须由前驱节点设置,因为其语义是“我释放锁时必唤醒后继”,该责任只能由已就绪的前驱承担;后继入队未完成,无法安全自设,且AQS中仅前驱在park前通过shouldParkAfterFailedAcquire中的CAS设置SIGNAL。
-
setSoTimeout()仅控制单次阻塞读操作的空等超时,即无数据可读时最多等待时长;对connect()、write()无效,不约束整体请求耗时,需配合连接超时与业务层超时共同实现端到端控制。
-
isDone()仅是任务结束状态的快照,不阻塞也不支持超时;真正实现带超时等待必须使用get(timeout,unit),它会阻塞并抛出TimeoutException、InterruptedException或ExecutionException。
-
NoSuchMethodError是运行时LinkageError异常,因编译与运行时类版本不一致导致方法缺失;需通过堆栈定位目标类、签名及调用位置,结合-verbose:class或代码打印确认实际加载jar,再用dependency:tree分析冲突依赖,最后通过exclusions或force统一版本修复。
-
anyOf不能用于“首选快速响应”策略,因其只认完成不认成功,易将超时异常当有效结果;返回Object需包装或用applyToEither避免ClassCastException;必须校验result和ex有效性并设独立线程池、超时与兜底。
-
自动装箱与拆箱简化基本类型与包装类转换,但易引发空指针、性能问题及缓存陷阱;装箱发生于基本类型赋值给包装类或传参时,拆箱发生于包装类被当基本类型使用时。
-
64位HotSpot虚拟机中对象头默认占12字节,即8字节MarkWord(动态复用存储哈希码、锁状态、GC年龄等)加4字节压缩后的KlassPointer。
-
ByteBuffer.put不能直接写入非byte类型数据,必须用putInt()等专用方法;写入需严格对齐字节序与大小,注意remaining()空间、编码转换及flip()切换读写状态。
-
RandomAccessFile.setLength()是跨平台预分配文件空间的唯一可靠方式,调用内核接口瞬时扩展或截断逻辑长度,不写入数据、不触发I/O,但非稀疏文件创建;分布式场景须由主控节点统一调用,避免并发覆盖。