-
ServiceLoader是JDK原生SPI机制,通过META-INF/services/下接口全限定名配置文件加载实现类,懒加载、无参构造、不支持依赖注入,与Spring完全隔离,适用于简单插件场景。
-
HashSet能自动去重,因其底层基于HashMap,元素作为key存储,依赖equals()和hashCode()保障唯一性;自定义类必须正确重写这两个方法,否则去重失效。
-
模块化开发中变量暴露边界的本质是按需开放访问权限:包内用default实现高内聚协作,继承体系用protected+private控制能力边界,对外服务用public配合校验与防御性拷贝,再通过module-info.java二次过滤导出包。
-
需结构化记录关键变量变更,涵盖操作人、时间戳、变量名与作用域、脱敏前后值及调用链标识,通过@AuditVariable注解+AOP实现轻量审计,并接入ELK日志体系与告警。
-
答案:Java中通过Properties类和类加载器读取resources下的配置文件,如config.properties,使用InputStream加载并获取键值对,推荐ClassLoader方式确保JAR包内正常访问,注意处理文件缺失、编码及敏感信息存储问题,外部配置可用FileInputStream指定路径。
-
最常见的幂等失效原因是拦截器未注册或注解未被Spring扫描到;需确保拦截器加@Component、启用CGLIB代理、注解含RUNTIME保留策略和METHOD目标,且避免this调用。
-
IllegalFormatConversionException是Java中String.format()等方法因格式符(如%d)与参数类型不匹配而抛出的运行时异常,例如用%d传String、%f传Integer、%t系列传String等;需严格按Formatter语法匹配类型,优先用%s兜底或启用-Xlint:format编译检查。
-
Integer缓存池可扩容至-128~200000,通过-XX:AutoBoxCacheMax=200000实现;Long等类型缓存不可调,需用ConcurrentHashMap显式代理;验证用JFR或-XX:+PrintClassHistogram,判等必须用equals()。
-
peek()在队列为空时返回null而非抛异常;使用前必须判空,且多线程下无法保证peek()后元素仍存在,LinkedList按FIFO返回首元素,PriorityQueue返回堆顶优先级最高元素,ConcurrentLinkedQueue.peek()不保证实时性。
-
Java中括号默认为捕获组,影响group()索引、性能及替换行为;非捕获组(?:...)不占编号、不存结果、无性能开销;命名捕获组(?<name>...)在Java8+支持,仍占用编号且不可重名。
-
MySQL的REPEATABLEREAD通过首次查询生成ReadView并全程复用,确保事务内多次读取同一字段结果一致;同时用Next-KeyLock锁定行及间隙,防止并发写冲突和幻读,但无法自动解决应用层“先读后写”导致的逻辑丢失更新。
-
Trie树用于敏感词过滤最核心优势是一次扫描、多词匹配,时间复杂度仅O(M),远优于正则或循环匹配的O(N×M);其共享前缀结构既节省空间又加速跳转,兼顾高效性与策略扩展性。
-
必须在启动JVM时添加-XX:NativeMemoryTracking=detail,否则无法获取原生内存数据;仅支持off/summary/detail三级,生产环境推荐detail;参数须置于java命令最前,不可写为on或放在-jar后。
-
桶排序在大促积分场景中用于构建可伸缩低延迟的分拣与排名体系,核心是分而治之、范围映射与局部处理,而非直接排序。
-
Thread.setDefaultUncaughtExceptionHandler未生效的根本原因是设置时机过晚或仅对后续线程生效,且主线程异常不走该处理器;需在main开头设置,并单独为主线程、线程池、框架线程(如@Async)、UI线程分别配置handler。