-
ConcurrentHashMap是Java中线程安全映射的首选,采用分段锁或CAS提升并发性能,相比Hashtable和synchronizedMap更高效;其常用操作如put、get等均为线程安全,支持putIfAbsent、remove、replace及compute、merge等原子复合操作,可避免竞态条件;迭代器具有弱一致性,不抛出ConcurrentModificationException,允许遍历时其他线程修改;推荐使用forEach或entrySet遍历;性能优化建议包括合理设置初始容量
-
枚举中声明抽象方法并由各常量用{}块实现,是类型安全、编译强制检查的差异化策略;需配合私有字段复用共性数据,方法签名须稳定,适用于状态机等有限内聚场景。
-
Java内部类访问局部变量需为final或effectivelyfinal,根本原因是栈帧销毁后局部变量不复存在,而内部类对象存活于堆中;编译器通过值拷贝到隐式final字段来规避生命周期错位,final确保副本与原始值语义一致。
-
本文详解如何利用Collectors.groupingBy将对象流按自定义字符串键(由多个字段组合生成)高效分组,得到Map<String,List<T>>结构,避免冗余映射操作与类型不匹配问题。
-
findInLine常返回null,因其仅从当前扫描位置跳过前导空白后尝试匹配一次正则,不回退、不跨行、不重试;若前序操作(如nextInt)使位置停在空白处,且正则未覆盖该位置,则匹配失败。
-
java.util.concurrent包的核心定位是提供可组合、线程安全、有明确语义的并发构建块,而非synchronized或wait/notify的语法糖;典型工具如ArrayBlockingQueue、ForkJoinPool等直接解决生产者-消费者、任务分治等场景。
-
compareAndSet不等于绝对线程安全,因其仅校验值是否变化而忽略修改过程,导致ABA问题;AtomicStampedReference通过版本号防ABA,AtomicMarkableReference仅适用于二元状态切换。
-
InheritableThreadLocal在线程池中“复用旧值”是因为线程复用导致继承逻辑不触发,且上一次任务的值未remove,造成上下文污染;其浅拷贝仅复制引用,加剧并发风险;修复需手动set/remove或改用TransmittableThreadLocal。
-
LocalDate和LocalTime线程安全且不可变,修改操作返回新实例;但需避免静态缓存、错误混用可变对象、误用局部时间计算耗时或跨时区场景,解析须指定格式器,数据库交互需JDBC4.2+支持。
-
Java中处理字符串多余空格需区分首尾与中间:trim()仅去首尾空白,replaceAll("\s+","")压缩中间连续空白为单空格;推荐组合使用trim().replaceAll("\s+","")或ApacheCommons的StringUtils.normalizeSpace()。
-
super用于访问被隐藏的父类实例变量或调用被重写的父类方法;子类同名字段时必须用super.变量名访问父类变量;重写方法中需复用父逻辑时必须用super.方法名();构造器中用super()调用父类构造器且须为第一行。
-
Java学生成绩排序需实现Comparable或提供Comparator;List用sort()或Collections.sort(),数组用Arrays.sort();并列名次需手动计算rank=i+1;大数据量优先就地排序。
-
String类是Java中处理文本的核心工具,具有不可变性。1.提供equals、equalsIgnoreCase进行字符串比较,startsWith、endsWith判断前后缀,contains检查子串,isEmpty和isBlank判断空或空白内容。2.charAt获取指定位置字符,indexOf和lastIndexOf查找子串位置,substring实现截取操作。3.replace和replaceAll支持字符或正则替换,trim、strip系列方法去除空白,format用于格式化输出。4.spli
-
多维数组是构建邻接矩阵最直接的工具,用n×n二维数组表示n个节点连接状态,需节点编号与索引对齐(0到n−1),区分图类型初始化,支持O(1)查边和O(n)度统计,但增删节点需重建矩阵。
-
使用Optional.ofNullable可清晰统一处理前端模糊查询参数的判空、去空格和转like模式逻辑,避免因空值导致全表扫描,提升代码可读性与可维护性。