-
应警觉并避免if-else嵌套超过2层,因其混杂控制流、业务判断与副作用,导致可读性差、易出错、难测试;推荐用提前返回、Optional(适度)、策略映射和IDE检查约束。
-
JFR能每10ms采样线程栈,稳定捕获毫秒级抖动,而top仅显示整体CPU率、jstack为单次快照无法捕捉瞬时尖峰;必须用jcmd动态启动,关键事件包括jdk.ExecutionSample、jdk.JITCompilation、jdk.ThreadStart等。
-
Stream.iterate()默认无限,因只接受初始值和迭代函数,无内置终止条件;需用limit()截断或Predicate谓词终止。
-
局部变量表不实现内存高效分配,它只是编译期确定大小的固定结构;真正提升内存效率的是减少局部变量数量、复用变量、控制参数规模、避免逃逸,并配合逃逸分析实现栈上分配。
-
Math.abs()返回参数绝对值,Math.max()返回两数中较大值;二者均支持基本数值类型,需注意NaN处理和空指针风险。
-
Java对象生命周期始于类加载完成,终于垃圾回收清除,历经创建、使用、不可达、回收四阶段;类加载含加载、验证、准备、解析、初始化五步,初始化后方可new实例;实例化时分配堆内存、设对象头、默认初始化字段,再执行父类构造器→字段显式初始化→构造体;强可达时对象可正常使用;不可达后经GC标记清除,现代JVM通常跳过finalize直接回收。
-
Optional.ifPresent仅用于本地空值防护,不能解决微服务迁移中的上下文断裂、分布式容错等问题;它适用于DTO转换、配置读取等轻量场景,需配合契约定义、统一结果封装和降级机制保障变量安全。
-
Collections.binarySearch()是Java中专为已排序List设计的O(logn)查找方法,要求列表严格升序或按指定Comparator有序,否则结果未定义;返回≥0为找到元素的索引,<0则表示未找到且可推导插入位置。
-
用createElement()创建并添加元素需三步:创建节点、设置内容/属性、插入到DOM;关键在插入位置与方式,推荐用DocumentFragment批量插入以提升性能。
-
什么时候该调大-XX:CompileThreshold默认值10000意味着方法被解释执行满一万次才触发C1编译,对高并发短生命周期服务(比如SpringBootWebAPI)来说太保守——热点方法还没来得及编译,请求潮就过去了,C2更是遥遥无期。实操建议:-测试环境可先试-XX:CompileThreshold=1500,观察PrintCompilation日志里方法编译延迟是否明显缩短-生产环境慎用低于3000的值,否则C1编译线程争抢CPU,反而拖慢吞吐
-
IllegalStateException表示对象状态不合法,如在关闭的流中读取数据;IllegalArgumentException表示参数值不合法,如传入负数作为年龄。前者关注对象状态,后者关注输入参数,合理使用可提升代码健壮性。
-
本文介绍在SpringBoot项目中基于Log4j2实现“每个类输出到专属日志文件”的完整方案,涵盖Logger初始化规范、log4j2.xml配置要点,并提供可运行示例与关键注意事项。
-
单例模式确保一个类只有一个实例并提供全局访问点,其核心是私有构造函数、静态实例和公共静态获取方法。常见的实现方式包括饿汉式、懒汉式、双重检查锁和静态内部类,其中双重检查锁和静态内部类兼具线程安全与延迟加载。使用时需注意多线程安全、指令重排序、反射破坏和序列化问题,是创建型设计模式的典型代表。
-
Collectors.toList()是Java8StreamAPI中用于将流元素收集到List的常用收集器,返回的列表基于ArrayList实现、允许重复且不保证线程安全;基本语法为stream.collect(Collectors.toList()),常用于数据过滤、转换后收集,如字符串转大写或提取对象属性;注意事项包括:生成的列表不可直接修改结构、若需不可变列表应使用Collectors.toUnmodifiableList()(Java10+),指定实现类型可用Collectors.toColle
-
ServiceLoader.load()返回空迭代器却不报错,主因是类加载器隔离或路径错误:检查META-INF/services/接口全限定名文件是否在jar根路径、文件名无.class后缀、内容无空格/BOM、实现类public且含public无参构造器,并显式传入匹配的ClassLoader。