-
ListenableFuture更实用因其支持异步回调而非阻塞等待;需通过ListeningExecutorService创建,用Futures.addCallback注册成功/失败处理,transform/catching构建流水线,但Guava28+起为@Beta,新项目宜优先选CompletableFuture。
-
Java原生Map不支持双向查找,因其仅保证键→值单向映射且值可重复;Guava的BiMap通过强制键值均唯一实现双向映射,提供inverse()视图并保障一致性。
-
NIO与BIO的核心区别在于:BIO是阻塞式、面向流、一个连接一线程,适用于低并发场景;NIO是非阻塞、面向缓冲区、通过Selector实现单线程管理多连接,适合高并发高性能需求,现代Java后端多采用NIO及Netty等框架。
-
Waitingoncondition表示线程主动挂起等待条件成立,并非死锁,常见于Object.wait()、park()或NIO等场景,多数情况属正常阻塞,需结合调用栈与分布式锁上下文综合判断。
-
InternalError是JVM内部严重故障信号,不可被捕获处理;其出现表明JVM状态已不可信,应通过诊断日志、版本升级、环境排查定位根源,而非业务代码干预。
-
final字段必须在声明或构造方法中初始化且仅一次,编译器编译期强制检查并报错,禁止运行时修改;静态final需在静态块或声明时初始化,实例final绑定构造过程。
-
当XML字符串被连续多次转义(如<)时,StringEscapeUtils.unescapeXml()仅执行单层解码;需循环调用直至无变化,或根据预期转义层数精确调用多次。
-
基数排序适合处理固定长度的整数或字符串,按位分组计数、不比较大小,时间复杂度为O(d×(n+k));电话号码需清洗、统一为11位数字数组,再逐位进行稳定计数排序。
-
ArrayDeque通过循环数组连续存储提升L2缓存命中率:CPU以64字节cacheline预取相邻数据,连续布局使一次预取覆盖多个元素;而LinkedList节点分散,频繁cachemiss导致性能下降30%~60%。
-
Path.resolve用于解析路径片段为绝对路径,不构建映射但可配合对象实现变量→路径映射;推荐用resolve预计算paths对象,动态拼接时也应调用resolve而非字符串拼接。
-
InetAddress.getLocalHost()不可靠,因依赖hosts/DNS配置,易返回127.0.0.1或抛UnknownHostException;应改用Runtime.exec("hostname")获取主机名、遍历NetworkInterface过滤回环地址获取真实IPv4。
-
AQS是Java并发包中构建锁和同步器的底层框架,通过volatileintstate管理同步状态、CLH双向队列处理线程排队与唤醒,并提供独占/共享模式及模板方法(如tryAcquire),使开发者能定制同步语义而非直接同步变量。
-
flatMap更适合处理嵌套Optional,因为它能将Optional<Optional<T>>“压平”为Optional<T>,而map会逐层包装导致嵌套;其参数必须返回Optional,否则编译失败,且在上游为空时自动短路,语义更精准。
-
Array.newInstance()是Java反射创建数组的唯一标准方式,支持原始类型(用int.class等)和引用类型;原始类型必须传其Class实例(如int.class或Integer.TYPE),不可用Integer.class;可创建一维或多维数组,返回Object需强制转型。
-
向上转型安全但丢失子类特有方法,因编译器只认变量声明类型;向下转型需instanceof检查防ClassCastException;泛型擦除致运行时类型信息丢失;接口转换须遵循实现关系。