-
应优先使用LocalDateTime.now()获取本地时间,避免使用线程不安全、API陈旧的Date;跨时区场景用Instant或ZonedDateTime,转换需经ZoneId桥接,格式化须注意DateTimeFormatter模式差异。
-
序列化是将内存中对象的状态转换为字节流以持久化或传输,反序列化则还原对象;必须实现Serializable接口标记允许序列化,子类继承时建议显式实现,非transient非static字段须可序列化,serialVersionUID需手动维护确保兼容性。
-
UUID.randomUUID()慢是因为依赖SecureRandom访问/dev/random或/dev/urandom,引发I/O和熵池延迟,且高并发下存在锁争用;JDK9+优化分段锁但仍比纯内存计算慢10–100倍。
-
本文深入剖析Java中直接使用字节数组(byte[])与手动逐字节转为字符数组(char[])创建字符串时产生乱码的根本原因,重点揭示UTF-8多字节编码机制、Java字符模型及编码解码本质差异。
-
Java中不能靠抛异常实现优雅退出,因为异常机制非流程控制工具,会掩盖错误、破坏调用栈、干扰监控;应使用System.exit(int)明确退出意图,或采用分层返回与外部信号协调。
-
SynchronousQueue不是队列而是“手递手”通道,因它不存储元素,offer()和poll()总失败,仅put()与take()成对阻塞同步;size()恒为0,适用于严格配对的线程间一次性数据传递。
-
答案:使用Mockito可创建mock对象并验证行为。首先添加依赖,通过@Mock或Mockito.mock()创建mock对象,用when().thenReturn()设定返回值,verify()验证方法调用次数及方式,结合JUnit注解初始化提升效率。
-
Optional不能直接封装原始指针,因其仅表达值存在性、无生命周期管理、线程不安全且无法校验有效性;应使用自定义NativeHandle类封装指针并实现AutoCloseable/Cleaner,再用Optional<NativeHandle>安全表达可选原生资源。
-
三元运算符中基本类型字面量与可空包装类型混用会触发JVM强制拆箱导致NPE;应改用if-else、显式包装或Optional避免隐式类型转换。
-
用equals()比较字符串内容,别用==;equals()逐字符比较且安全处理null,但需非null对象调用;忽略大小写用equalsIgnoreCase();防NPE应字面量在左或用Objects.equals()。
-
Java的try-with-resources能自动关闭资源,前提是资源实现AutoCloseable接口;资源在try后括号内声明,执行结束时自动调用close()方法;关闭顺序与声明顺序相反;若try块和close均抛异常,try异常为主,close异常被压制并可通过getSuppressed()获取。
-
JavaPriorityQueue默认最小堆且非线程安全;要实现高优先级数字越大越先出,需传Comparator.reverseOrder()或自定义比较器;不支持O(logn)更新优先级或按值删除,remove()为O(n)且破坏堆结构。
-
cloneNode()的deep参数决定复制完整性:true深拷贝保留全部子结构与属性但不复制事件,false浅拷贝仅复制自身;均需处理ID冲突、事件重绑及显式挂载;跨文档须用importNode()。
-
导出CSV必须用try-with-resources关闭BufferedWriter,字段含逗号或中文需加英文双引号;导入不可用split(","),应使用OpenCSV或手动解析引号;统一指定UTF-8编码并处理BOM头,Contact应为POJO。
-
成功执行java-jarxxx.jar的前提是:JRE/JDK已安装且版本兼容,java命令可用;JAR包为可运行格式,即MANIFEST.MF中含正确Main-Class属性;依赖已内置(fatjar)或显式指定;文件有读取权限,路径无空格或中文。