-
flatMap可将List<List<T>>展平为单层Stream<T>,核心是将每个内层列表转为Stream再合并;需过滤null/空列表以确保安全;还可逐层处理更深嵌套结构。
-
Optional.ifPresent仅用于本地空值防护,不能解决微服务迁移中的上下文断裂、分布式容错等问题;它适用于DTO转换、配置读取等轻量场景,需配合契约定义、统一结果封装和降级机制保障变量安全。
-
Java中long和float字面量需加L/F后缀,因整数默认int、浮点数默认double;如10000000000无L会超int范围报错,3.14无F因double转float隐式降级被禁止。
-
Java中的Stream只能被消费一次,执行终端操作后再次使用会抛出IllegalStateException;正确做法是每次从数据源重新创建新Stream或用Supplier封装stream()调用。
-
DelayQueue必须存实现Delayed接口的对象,需同时重写getDelay和compareTo方法;取任务必须用take()阻塞等待,消费应单线程取出后交由业务线程池异步处理,并配合外部存储实现持久化与幂等关单。
-
可通过ResultSet.getMetaData()获取元数据,按列索引(从1开始)调用getColumnCount()、getColumnName()、getColumnLabel()、getColumnTypeName()、getColumnType()等方法获取列数、列名、标签名、数据库类型名及JDBC类型码,并依映射关系转为对应Java类型。
-
FileSystems.getDefault()返回JVM启动时绑定的本地操作系统文件系统实例(如Windows的NTFS、Linux的ext4),是单例且线程安全的,但不支持jar、网络或内存路径,仅限本地磁盘访问。
-
LinkedHashMap通过双向链表维护插入或访问顺序,遍历时按插入顺序输出;设置访问顺序后可实现LRU缓存;序列化和复制时能保留顺序,适用于配置项、有序响应、缓存等场景。
-
CyclicBarrier适用于多阶段并行计算,支持重复使用,每轮等待所有线程到达后自动重置;CountDownLatch不可重用,频繁新建实例会增加开销和出错风险。
-
核心是先稳数据模型与操作边界:employee表含id、name、emp_code;attendance表含employee_id、work_date(DATE)、status,并建联合唯一索引uk_emp_date;用PreparedStatement或MyBatis动态SQL,查考勤需用LocalDate区间查询,批量更新须事务控制。
-
企业级Java开发环境需统一JDK版本(如OpenJDK17LTS)、用SDKMAN!管理多版本;Maven为主构建工具,配置私有仓库镜像与依赖管理;IDEA标准化配置代码化;DockerCompose支撑本地中间件;JVM参数与调试预置,强调可控、可审计、可批量部署。
-
ArrayList采用1.5倍扩容而非2倍,是为了降低连续内存碎片率:2倍扩容(如100→200)导致闲置空间激增(如存120个元素浪费80位),加剧老年代碎片化和GC压力;1.5倍(100→150)闲置更少(仅浪费30位),内存利用率稳定在70%~85%,旧数组更易被完整回收。
-
add()遍历时必报ConcurrentModificationException,因迭代器的expectedModCount与集合modCount不一致触发fail-fast机制;安全做法包括暂存后批量添加、倒序遍历、ListIterator.add()或改用CopyOnWriteArrayList等。
-
new出来的对象不一定在堆上,因逃逸分析可判定其是否逃逸:未逃逸时JVM可栈上分配或标量替换;方法逃逸或线程逃逸则必须堆分配。
-
Java中对象克隆分为浅克隆和深克隆。1.浅克隆通过实现Cloneable接口并重写clone()方法,复制基本类型值和引用类型地址,导致原对象与克隆对象共享引用对象;2.深克隆则确保完全独立,可通过重写clone()递归克隆、序列化反序列化或使用JSON转换等方式实现,适用于需隔离对象的场景。