-
接口幂等性指多次调用结果一致,常用实现方式包括:1.唯一标识+Redis缓存,利用SETNX防止重复提交;2.数据库唯一约束,通过唯一索引避免重复插入;3.状态机控制,条件更新确保状态流转幂等;4.Token机制,防重令牌一次性使用。实际中可组合使用,如Redis与数据库约束结合,保障核心操作数据一致性。
-
BankAccount类须私有化字段并严格校验:balance、accountNumber(final)、name(非空校验);转账必须由Bank类原子执行,禁止Account间直调;main仅作交互胶水层;边界测试优先于正常流程。
-
brewinstallopenjdk默认安装openjdk@21(截至2024年中),路径为/opt/homebrew/opt/openjdk@21/libexec/openjdk.jdk,需手动设JAVA_HOME并用/usr/libexec/java_home-v21注册生效。
-
清空ArrayList最推荐使用clear()方法,它会直接移除所有元素并释放引用,使所有指向该列表的引用均生效,而重新newArrayList()仅让变量指向新对象,原列表若无其他引用才会被回收;clear()不创建新对象,性能更高,适用于共享列表场景,优先推荐使用clear()。
-
HashSet遍历顺序不固定,因其底层基于HashMap的哈希桶分布受hashCode、容量、JDK版本等影响;需插入顺序用LinkedHashSet,需排序用TreeSet。
-
类是对象的模板,定义属性和方法;对象是类的实例,通过new创建并独立存储数据;构造方法初始化对象,访问修饰符控制成员可见性,实现封装。
-
静态成员属于类而非实例,可通过类名直接访问。1.静态变量被所有实例共享,用于存储公共数据,如对象计数;2.静态方法可直接调用,常用于工具功能,不能访问非静态成员;3.静态块在类加载时执行一次,用于初始化静态资源。合理使用可提升效率。
-
必须继承Exception或RuntimeException,因JVM仅识别Throwable子类异常;继承Exception强制调用方处理,适合业务可控错误;继承RuntimeException则无需声明,适用于程序逻辑错误。
-
LinkedBlockingQueue是Java中基于链表的阻塞队列,支持有界和无界模式,常用put/take实现生产者-消费者模型,适用于线程池任务队列及多线程解耦通信。
-
可见性是指线程修改共享变量后其他线程能否立即看到该修改;因JMM中线程工作内存与主内存分离,且存在缓存、优化和重排序,导致修改未及时同步,从而引发可见性问题。
-
retainAll本质是原地保留交集,直接修改调用方集合;需浅拷贝保原集合、确保equals/hashCode正确实现;参数为null抛NPE;性能优化关键在于将参数转HashSet以使contains达O(1)。
-
Future.get()默认阻塞,需用超时重载或isDone()判断;抛出InterruptedException、ExecutionException、TimeoutException须分别处理;禁在UI/Servlet主线程调用;cancel()不保证资源清理,任务需自行响应中断。
-
SpringBoot应用部署后大文件(>100MB)上传返回503错误,请求甚至未到达控制器——根本原因常是multipart功能未显式启用,而非仅配置大小限制。
-
Java中Cloneable仅为标记接口,克隆逻辑由Object.clone()实现;需重写publicclone()并调用super.clone()获得浅拷贝,引用类型须手动深拷贝;推荐使用拷贝构造器或静态工厂方法替代。
-
JavaIO是阻塞式且低效于高并发,NIO通过非阻塞和复用机制提升性能。1.JavaIO基于流模型,每个连接需独立线程处理,导致高并发下线程开销大;2.NIO引入通道、缓冲区和选择器,实现非阻塞I/O,单线程可管理大量连接;3.文件操作上,NIO的内存映射和零拷贝减少数据拷贝与CPU开销;4.网络通信中,Selector监听多事件,SocketChannel与ServerSocketChannel配合实现高效连接处理;5.使用NIO需注意Selector空轮询、Buffer管理、Direct/HeapBu