-
Deque.peek()返回队首元素但不移除,poll()则移除并返回队首元素;二者配合实现“先预览后消费”的非破坏性预检逻辑,需始终配对使用且先判空再调用。
-
Stream.sorted配合Comparator.reversed仅对整个比较器取反,无法实现各字段独立升/降序;真正多级反向排序需为每个字段显式指定顺序,如升序省略、降序用Comparator.reverseOrder()。
-
firstKey()返回排序后最小键而非插入顺序键;TreeMap基于红黑树按自然序或Comparator排序,firstKey()直接返回最左节点引用,时间复杂度接近O(1),但需注意Comparator逻辑与线程安全性。
-
SpringBoot默认使用Jackson的SNAKE_CASE命名策略时,会将Java驼峰字段(如firstName)自动映射为下划线格式(如first_name)的JSON键,导致直接发送{"firstName":"John"}时字段值为null。
-
Java注解是一种为代码提供额外元数据的特殊“标签”,不影响程序逻辑,但能被编译器、JVM或其他工具读取和处理。1.注解用于声明式编程,提升代码表达力、可维护性和自动化程度;2.作用包括编译时检查、替代XML配置、生成代码或文档;3.自定义注解开发涉及定义注解类型、添加元注解(如@Target、@Retention)、定义成员属性、应用注解、运行时解析;4.解析方式主要有反射机制和编译时注解处理器;5.常见问题包括@Retention策略错误、@Target范围不明确、@Inherited误解、注解成员类
-
ThreadLocal跨线程失效是设计使然,并非bug;InheritableThreadLocal仅在newThread时有限继承;生产环境应使用TransmittableThreadLocal(TTL)配合任务包装与线程池适配实现可靠透传。
-
Java集合框架提供统一高效的数据结构,核心接口包括Collection、List、Set、Queue和Map;常用实现有ArrayList、LinkedList、HashSet、TreeSet、HashMap、LinkedHashMap、TreeMap;选择依据是主要操作需求;线程安全需用Collections工具类或concurrent包;注意初始化容量、null限制及迭代器失效问题。
-
Java文件上传核心是处理multipart/form-data请求,SpringBoot用MultipartFile快速实现,原生Servlet需ApacheCommonsFileUpload;须重命名文件、校验类型、限大小、隔离上传目录。
-
并发是任务“看起来同时”执行,依赖时间片切换;并行是“真正同时”执行,取决于CPU核心数与JVM调度。单核只能并发,多核才可能并行;可用核心数由Runtime.getRuntime().availableProcessors()返回。
-
Double.isFinite(x)校验x是否为有限实数,即排除NaN和±∞;它不检查溢出边界、精度丢失或物理合理性,仅用于拦截已失效的浮点结果。
-
PooledByteBufAllocator通过三级缓存(线程局部PoolThreadCache、PoolArena共享队列、PoolChunk分页)显著降低高并发下内存分配开销,但必须显式调用release()才能真正复用,否则仍会内存泄漏。
-
本文介绍如何在OptaPlanner中优雅支持周期性员工可用性(如“每周五不可用”),避免手动复制事件;核心思路是分离“模式定义”与“运行时匹配”,通过EmployeeAvailabilityPattern类配合流式约束动态校验排班冲突。
-
Reference.reachabilityFence并非修复NPE的万能药,而是防止JVM过早判定对象不可达的编译器屏障;它仅在对象本应可达但因激进优化(如逃逸分析)被误回收时生效,且必须紧邻最后一次使用、在同一栈帧内调用,配合Cleaner或PhantomReference使用才有效。
-
桥接方法不直接提升分布式系统稳定性,它是Java编译器为解决泛型类型擦除导致的多态语义问题而生成的JVM内部机制,作用限于单JVM方法分派,与网络容错、消息一致等分布式核心问题无关。
-
局部变量复用本身不会导致垃圾回收器“误判”,真正需防范的是因复用延长对象强引用生命周期;应将临时变量声明在最小作用域块内、避免循环外声明赋值、检查隐式强引用链,并借助逃逸分析与GC日志验证效果。