-
Java中forEach无法直接获取嵌套List的最内层元素,因其仅遍历当前层级;需用flatMap扁平化或改用传统循环;Thymeleaf需显式访问Map.Entry的key/value;MyBatis的foreach不支持跨层级集合;树形结构Stream递归需加深度控制。
-
使用-verbose:class可直接查看每个类的加载器和路径,有效排查Jar包混杂导致的类冲突;启动时添加该JVM参数即可,在控制台输出中重点比对类名、来源路径和加载时机,并结合getClassLoader()打印确认加载器实例。
-
start()启动新线程实现并发,run()仅为普通方法调用;start()由JVM调度创建独立线程并自动执行run(),而run()在当前线程串行执行;start()只能调用一次,run()可重复调用。
-
开闭原则是“对扩展开放、对修改关闭”,核心是不破坏已有逻辑的实现;可通过新增类、接口、注册表或依赖注入实现扩展,而非修改原有代码。
-
byte状态掩码比boolean[]或结构体更优,因其严格占1字节、无填充、跨平台一致;掩码须为2的幂次(如1<<0、1<<1),操作用&、|=、&=~、^=实现原子性读写。
-
AtomicLongFieldUpdater是用于对volatilelong实例字段进行无锁原子更新的工具类,基于反射+Unsafe实现CAS,要求字段为volatile、long类型、非static非final,且updater需在字段可见范围内声明。
-
Objects.toString()能安全将可能为null的对象转为字符串并支持默认值,避免空指针异常;用法为Objects.toString(obj,"默认值"),适用于日志、调试等只读展示场景。
-
Java枚举的compareTo方法默认按声明顺序比较,因其内部基于ordinal值实现;ordinal从0开始递增,对应常量声明位置,故RED<GREEN<BLUE;但ordinal属实现细节,不建议持久化,特殊排序应使用外部Comparator。
-
Collectors.averagingInt()仅计算整型字段算术平均值并返回double,不能直接生成财务报表;它适用于非金额类整数指标(如数量、天数),但不支持空流且存在浮点误差,财务场景应优先用BigDecimal配合自定义收集器。
-
Java死锁需主动预防:统一按System.identityHashCode()升序加锁、用ReentrantLock.tryLock()实现超时与可中断、避免同步块内调用外部方法,同步块仅做数据操作。
-
ServiceLoader是JDK原生SPI机制,通过META-INF/services/下接口全限定名配置文件加载实现类,懒加载、无参构造、不支持依赖注入,与Spring完全隔离,适用于简单插件场景。
-
getInterfaces()仅返回直接声明的接口,不递归获取父接口;接口调用时返回其直接extends的父接口;需手动递归+去重才能获得完整继承链;泛型信息丢失,须用getGenericInterfaces()获取。
-
需结构化记录关键变量变更,涵盖操作人、时间戳、变量名与作用域、脱敏前后值及调用链标识,通过@AuditVariable注解+AOP实现轻量审计,并接入ELK日志体系与告警。
-
答案:Java中通过Properties类和类加载器读取resources下的配置文件,如config.properties,使用InputStream加载并获取键值对,推荐ClassLoader方式确保JAR包内正常访问,注意处理文件缺失、编码及敏感信息存储问题,外部配置可用FileInputStream指定路径。
-
IllegalFormatConversionException是Java中String.format()等方法因格式符(如%d)与参数类型不匹配而抛出的运行时异常,例如用%d传String、%f传Integer、%t系列传String等;需严格按Formatter语法匹配类型,优先用%s兜底或启用-Xlint:format编译检查。