-
时间复杂度取决于各层循环的迭代次数表达式,而非嵌套层数;例如三层循环可能为O(n×m),关键看每层是否依赖同一变量n。
-
优先使用组合而非继承,因组合支持运行时替换、降低耦合、符合单一职责;继承仅在满足“是”关系且父类明确设计为可继承时才安全。
-
Checkstyle插件不生效主因是模块未绑定、实时扫描未启用或版本不匹配;需确认Java语言级别、用绝对路径、重载配置、降级至8.36适配P3C,并统一各组件版本。
-
newThread()一用就卡,因每次创建都触发系统调用、分配8MB内核栈、切换态,1000次即耗时百毫秒且占8GB虚拟内存;CachedThreadPool无上限更危险;应使用有界ThreadPoolExecutor并合理配置参数。
-
DecimalFormat格式化结果为String,不可直接用于数学运算;需参与计算时应优先使用BigDecimal配合setScale和HALF_UP模式确保精度与四舍五入可控。
-
垃圾回收是JVM自动管理内存的核心机制,通过识别并清除堆中不再被引用的对象来释放内存。Java采用可达性分析算法判断对象是否可回收,以GCRoots为起点,未被引用链关联的对象被视为垃圾。常见的回收器包括Serial、Parallel、CMS(已弃用)、G1、ZGC和Shenandoah,适用于不同场景。堆内存分为年轻代和老年代,新对象先分配在Eden区,经历多次MinorGC后存活的对象晋升至老年代,老年代触发的FullGC较慢,应尽量减少其频率。合理编码与JVM调优可提升性能。
-
Java版本怎么选:OpenJDK还是OracleJDK?容器里别用OracleJDK,授权和体积都是坑。DockerHub上官方openjdk镜像已覆盖主流版本(11/17/21),直接拉取即可。JDK17是当前LTS中兼容性、GC行为最稳的选择,除非项目强依赖JDK8的javax.xml.bind等废弃包——那种情况得加--add-modulesjava.xml.bind启动参数,但更建议升级代码。生产环境优先用openjdk:17-jre-slim,比-jdk少装编译工具,镜像小3
-
Java7多异常捕获需满足互不相关的已检查或运行时异常、用|分隔、e为最近公共父类;不支持父子类异常合并;无法直接调用子类特有方法,需instanceof判断;性能与多个catch无差异;适用于处理逻辑完全一致的场景。
-
OutputStreamWriter的核心作用是将字符按指定编码转换为字节并写入底层字节流,作为字符流与字节流间的编码桥梁;必须包装现有OutputStream,需显式指定编码(如UTF-8),写入后应flush或close,可配置错误处理策略。
-
默认返回HashMap,不保证顺序;需有序用LinkedHashMap::new;多字段分组推荐record组合键;统计数量用counting();key为null直接抛NPE,须提前处理。
-
泛型是编译期类型契约而非语法糖,应在逻辑相同但数据类型不同的场景定义泛型类,优先使用泛型方法;需合理约束T,避免过度约束与擦除陷阱,并正确运用协变/逆变。
-
增强for循环底层基于Iterator实现,编译后转为hasNext()和next()调用;遍历时修改集合结构会抛ConcurrentModificationException;安全删除须用iterator.remove()且需在next()后调用;ArrayList的Iterator性能优于LinkedList;CopyOnWriteArrayList不支持remove();自定义集合需正确实现Iterable与Iterator。
-
final成员变量必须在构造完成前初始化且仅赋值一次;支持声明时赋值(简洁线程安全)、构造器内赋值(最常用,支持校验)、实例初始化块(少用,封装公共逻辑)及staticfinal类常量(声明或静态块初始化)。
-
null表示数组未初始化,length==0表示已创建但无元素;必须先判null再判length,推荐用Objects.nonNull(arr)&&arr.length==0确保安全。
-
本文详解如何正确处理JSON字符串中嵌套JSON(即JSON内容以转义字符串形式存在)的反序列化难题,重点解决Jackson因未正确转义导致的解析异常,并提供可落地的代码示例与最佳实践。