-
Java中Arrays.toString()不支持自定义格式,推荐用StringJoiner(可设分隔符、前后缀,空数组返回“[]”)、Arrays.stream()+Collectors.joining(支持元素映射和链式调用)或手动StringBuilder拼接(性能高,需自行处理边界)。
-
Java枚举本质是特殊类,强制具备私有构造、定义即创建、语法限定实例有限三大特性:构造方法默认且只能为private;所有实例在类加载时一次性创建并全局唯一;枚举值必须在定义中显式列出,编译期确定且不可扩展。
-
FutureTask是实现Runnable和Future接口的可取消异步计算包装器,支持直接run()执行、多次调用(仅首调计算)、非线程池环境使用;而普通Callable需经ExecutorService封装才能执行。
-
StringBuilder比+拼接快,因其内部维护可变char数组,append()复用内存,仅扩容时新建数组;而String不可变,每次+都生成新对象,增加GC压力。
-
CopyOnWriteArrayList.iterator()返回不可变快照,遍历基于创建时的数组副本,无法感知后续增删改操作;不支持remove()/set(),调用抛UnsupportedOperationException;读无锁、写加锁并复制数组,适用于读多写少场景。
-
Java类型转换分自动(小→大,安全)和强制(大→小,需显式,有丢失风险);含引用类型转换、装箱拆箱(注意缓存与空指针)及字符串手动转换(parseXxx/valueOf)。
-
Java中if-else需防坑:必加花括号{}、字符串判空用"str".equals()或Objects.equals()、多条件按null检查→无副作用→高开销顺序排列、elseif链须加finalelse并日志或抛异常。
-
答案是通过拆分条件、使用变量、卫语句和括号提升可读性。将复杂条件封装为私有方法如isAdminEligible,使主逻辑清晰;用布尔变量命名中间结果,分离条件与行为;采用卫语句提前返回,减少嵌套层级;显式添加括号明确逻辑优先级,避免歧义;最终实现代码自解释,强调清晰优于简洁。
-
异常链是Java内置的cause机制,通过Throwable(String,Throwable)构造器自动构建Causedby:嵌套堆栈,用于跨层封装、补充业务上下文、受检转非受检三类场景,避免丢弃关键线索。
-
IntelliJIDEA中配置JDK需协调项目SDK、模块SDK和语言级别:先在ProjectStructure→Project设置项目SDK及匹配的语言级别;再在Modules→Dependencies中确认或调整模块SDK;最后同步Maven/Gradle的编译插件版本,必要时清理缓存重启。
-
IntelliJIDEA中Lombok插件不生效需确认三件事:安装启用插件、开启AnnotationProcessing、构建工具中正确声明compile范围依赖;新版Lombok1.18.32与Jackson兼容问题需显式配置lombok.config;@Builder与@AllArgsConstructor同用易冲突,推荐@RequiredArgsConstructor+@Builder;单元测试中失效多因testclasspath缺失Lombok依赖或IDE缓存未更新。
-
ForkJoinPool专用于可递归拆分的CPU密集型任务,如归并排序、树遍历、并行reduce;不适用于I/O多、不可分或耗时差异大的场景。
-
accessOrder必须显式设为true才启用访问顺序,使get()或put()已存在key时将对应Entry移至链表尾部;默认false按插入顺序维护,LRU失效。
-
Java没有Character.isChinese方法,应使用Character.UnicodeBlock.of()判断CJK相关区块,覆盖扩展A/B区及兼容汉字,避免仅用0x4E00–0x9FFF范围。
-
CountDownLatch是Java中用于线程同步的工具,通过计数器实现一个或多个线程等待其他线程完成任务后再执行。初始化时设定计数值,每个任务完成后调用countDown()使计数减一,等待线程调用await()阻塞直至计数归零。适用于并行任务协调、服务启动依赖、数据加载聚合等场景。与CyclicBarrier不同,CountDownLatch为一次性使用,不可重置,适合“等待所有任务完成”的模型。使用时需注意将countDown()放入finally块防止遗漏,避免因异常导致计数不归零;建议使用带超