-
Java提供了内置的java.text.Normalizer类,支持按Unicode标准(如NFD、NFC、NFKD、NFKC)对字符串进行规范化处理,从而实现语义等价的字符串比较,有效解决重音符号、组合字符、全角/半角、兼容性字符等导致的匹配异常问题。
-
Stream.peek可调试数据流,它作为中间操作在不改变流的前提下打印日志,帮助定位过滤、映射等环节问题,需注意避免副作用并结合日志框架使用。
-
Java序列化是冻结对象状态并编码成字节流,反序列化是按协议重建对象并恢复字段值;Serializable仅为JVM启用默认序列化流程的标记接口,未实现则抛NotSerializableException。
-
instanceof判断null直接返回false而非抛异常;Java16起支持模式匹配语法,如if(objinstanceofStrings),变量s在if块内自动绑定且非null,但不支持泛型类型、基本类型及作用域外访问。
-
Java字符串+运算符由编译器优化:编译期常量折叠为单个字符串,运行时自动生成StringBuilder.append()链式调用并转toString;循环中滥用会导致O(n²)性能问题。
-
EnumMap比HashMap快在跳过哈希计算、避免冲突、省键引用,以ordinal直接数组寻址;但受限于枚举类型、不支持null、非线程安全、序列化困难且类加载器敏感。
-
优先用isBlank()校验字符串是否为空,因它会trim后判断,避免"\t\n"被误判为非空;isEmpty()仅判长度,适用于对空白敏感场景。
-
Exchanger怎么在双缓冲里交换两个缓冲区Java的Exchanger本质是线程间**成对同步交换对象**的工具,用在双缓冲场景时,它不负责分配内存、不管理读写状态,只管“等两个线程都到齐了,就互换手里的缓冲区引用”。典型用法是:一个线程持续往A缓冲区填数据(生产),另一个线程从B缓冲区取数据处理(消费),填满/取空后双方调用exchange()换一次引用,角色轮转。必须严格成对调用——一个线程调用exchange(buffer)后,必须有且仅有一个另一线程在同一Ex
-
Java中记录异常堆栈应优先使用日志框架(如SLF4J)直接传入Throwable对象,自动格式化完整堆栈;开发调试可用printStackTrace(),生产环境禁用;需字符串时用StringWriter+PrintWriter捕获;务必附加业务上下文。
-
使用synchronized或ReadWriteLock确保多线程下配置文件读写安全,结合内存缓存与定时持久化提升性能,通过WatchService监听外部变更,保证数据一致性与高效访问。
-
Java简单搜索应优先用ArrayList/HashMap配合stream().filter()实现内存模糊匹配,TreeSet结合subSet()支持大小写不敏感前缀搜索,需预处理null和空值并避免无效搜索。
-
InvocationTargetException是什么,为什么它总在反射里冒出来它不是你代码写错了,而是被反射调用的那个方法自己抛了异常,InvocationTargetException只是“套壳”——把原始异常包了一层再扔出来。JVM要求反射调用必须统一用这个包装类,否则没法区分“反射失败”和“目标方法失败”。常见错误现象:InvocationTargetException堆栈里看不到你写的业务异常,只看到getCause()才是真凶;IDE调试时断点停在invoke()那行,
-
Collections.frequency适用于单元素频次统计,语义清晰但仅支持精确equals比较;Stream.groupingBy适合全量频次统计,性能更优但需注意null键和自定义对象的equals/hashCode实现。
-
CharArrayReader是Java中用于直接读取内存中char[]数组的轻量级字符输入流,无I/O开销、零拷贝、响应快,适用于需将已有字符数组作为Reader传入流式API的场景。
-
ConcurrentHashMap的putIfAbsent不是绝对原子,因其仅对key插入做CAS保护,value构造副作用(如new对象)仍会执行;正确做法是用computeIfAbsent延迟构造。