-
forEach不支持受检异常且无容错机制,应避免在其中写核心业务逻辑;需容错时优先用for循环或map+Optional封装结果统一处理。
-
setFetchSize()控制JDBC驱动分批从服务器拉取结果集的行数,非数据库端限制返回量;MySQL需配useCursorFetch=true才生效,PostgreSQL默认支持游标式获取。
-
使用Optional.ofNullable可清晰统一处理前端模糊查询参数的判空、去空格和转like模式逻辑,避免因空值导致全表扫描,提升代码可读性与可维护性。
-
读懂JDK8-XX:+PrintGCDetails日志的关键是抓住元空间变化、分代内存水位、GC事件类型与耗时三类核心信息,重点识别晋升异常、FullGC频繁、GC耗时突增、老年代持续上涨四类问题信号。
-
isEmpty()更适合实时监控容量,因其时间复杂度低、无副作用、并发下更稳定,而size()在部分集合(如懒加载代理、ConcurrentHashMap.keySet())中可能触发计算、返回估算值或引发N+1查询。
-
封装是将属性和行为包装在类中,通过private隐藏字段并提供getter/setter方法控制访问,结合构造器校验和行为封装,确保对象状态安全,降低耦合,提升代码可维护性。
-
受检异常是编译期契约机制,非控制流工具;应通过分层异常处理、语义化包装(如将SQLException转为DataAccessException)和统一异常处理器(如@ControllerAdvice)实现精准响应,避免在业务逻辑中用多层catch做分支。
-
Elasticsearch默认的standard分析器会丢弃#、+等非字母数字字符,导致含特殊符号的标题无法被精确匹配;本文详解两种可靠方案:利用.keyword子字段进行精确匹配,或自定义分析器保留特殊字符。Elasticsearch默认的standard分析器会丢弃`#`、`+`等非字母数字字符,导致含特殊符号的标题无法被精确匹配;本文详解两种可靠方案:利用`.keyword`子字段进行精确匹配,或自定义分析器保留特殊字符。
-
Java启动时加载的JDK取决于PATH中首个java可执行文件所在路径,再反推其JDK根目录;JAVA_HOME不参与java命令调用,但被Maven等工具链直接读取。
-
NumberFormat.getCurrencyInstance()受系统区域设置影响,需显式传入Locale(如Locale.CHINA);format()仅接受Number子类,须校验null和类型;须同时设最小/最大小数位及舍入模式;非线程安全,应避免共享实例。
-
LRU缓存不依赖访问频次,而是按最近使用时间淘汰;若需频次计数,实为LFU策略,可用keys[]、values[]、counts[]三个平行数组实现,查找、更新、淘汰均为O(N)时间复杂度。
-
Instrumentation本身不直接提供方法耗时监控能力,它仅是JVM提供的底层agent构建API;真正实现生产级变量级(按方法签名、参数特征动态筛选)耗时监控,必须结合字节码增强(如ByteBuddy/ASM)、运行时采样策略与干扰过滤机制,而非简单调用addTransformer即可开箱即用。
-
多个catch块必须子类在前、父类在后;多异常捕获(|)要求类型互不继承;兜底异常不可过宽;catch内抛异常不会触发后续catch。
-
String.repeat()是Java11新增方法,低版本不支持;需确保JDK/JRE≥11并配置Mavensource/target;Java8可用StringBuilder或Collectors.joining()安全替代。
-
UnresolvedAddressException表明异步连接前主机名未解析为IP,需提前异步解析地址而非捕获该异常;推荐用CompletableFuture包装InetAddress.getAllByName或使用Vert.x/Netty等框架内置异步DNS解析。