-
ArrayDeque通过循环数组连续存储提升L2缓存命中率:CPU以64字节cacheline预取相邻数据,连续布局使一次预取覆盖多个元素;而LinkedList节点分散,频繁cachemiss导致性能下降30%~60%。
-
Path.resolve用于解析路径片段为绝对路径,不构建映射但可配合对象实现变量→路径映射;推荐用resolve预计算paths对象,动态拼接时也应调用resolve而非字符串拼接。
-
InetAddress.getLocalHost()不可靠,因依赖hosts/DNS配置,易返回127.0.0.1或抛UnknownHostException;应改用Runtime.exec("hostname")获取主机名、遍历NetworkInterface过滤回环地址获取真实IPv4。
-
AQS是Java并发包中构建锁和同步器的底层框架,通过volatileintstate管理同步状态、CLH双向队列处理线程排队与唤醒,并提供独占/共享模式及模板方法(如tryAcquire),使开发者能定制同步语义而非直接同步变量。
-
Java集合对null支持不统一:HashMap等宽松派允许null,TreeMap等严格派因排序或并发歧义禁止null;Stream需filter或Optional处理null;推荐用emptyList、Optional、枚举替代null。
-
接口应按调用方角色而非功能模块拆分,如LoginCapable、EmailCapable、ReportCapable;若实现类超1/3方法为空或抛异常,即违反接口分离原则,需及时重构。
-
异常信息必须包含上下文,不能只抛newRuntimeException("出错");应拼入关键变量、状态或输入值,并用带cause的构造函数保留原始堆栈;日志级别需匹配异常性质,WARN用于业务校验失败,ERROR用于系统级故障。
-
自动装箱拆箱是编译器在int与Integer间隐式转换的机制,提升泛型集合使用便利性,但带来缓存陷阱、空指针和性能开销问题,需谨慎处理判等、空值及Stream链式调用。
-
ConcurrentHashMap通过分段锁(JDK7)或CAS+synchronized(JDK8+)解决HashMap的线程不安全问题,支持高并发读写,避免ConcurrentModificationException、数据丢失和死循环。
-
最可靠方式是通过字节码分析Lambda运行机制:invokedynamic仅为占位符,实际逻辑由LambdaMetafactory引导方法和动态生成的$$Lambda类执行,其对应静态或实例方法可通过javap验证,动态类名在运行时生成且不可直接加载。
-
default方法不能访问实现类私有字段或独有方法,只能调用接口已声明的抽象方法和其他default方法;可通过新增抽象方法暴露状态,构建契约化行为骨架。
-
RESTfulAPI中应使用Optional.ofNullable().orElseThrow()处理“本应存在却缺失”的业务空值,配合@RestControllerAdvice统一返回标准错误响应,避免null或默认值;非业务空场景(如分页无数据)应返回200空列表。
-
启用-XX:+PrintGCDetails后,GC日志中直接反映晋升行为的关键字段是:tenuringthreshold(显示为newthreshold)、survivor容量与使用量、oldgen增量,以及PSYoungGen存活大小变化;其中newthreshold值动态体现实际晋升年龄门槛,oldgen增量与年轻代存活量差值可量化晋升字节数,Survivor区饱和时newthreshold陡降或归零即表明强制晋升启动。
-
CompletableFuture异步异常处理需可感知、可分类、可恢复:exceptionally()用于统一兜底;handle()支持成功/异常双路径精细化处理;whenComplete()专注副作用清理;组合策略实现分层捕获与主动恢复。
-
是的,TreeSet底层基于TreeMap实现,而TreeMap使用自平衡红黑树,保证有序性和O(logn)时间复杂度,但要求元素可比较且compareTo与equals逻辑一致。