-
数组长度固定、不支持泛型、缺乏内置操作,而集合框架提供标准化实现:ArrayList支持随机访问,HashSet自动去重,TreeSet有序存储,HashMap高效查找,且需注意容量预设、hashCode/equals重写、遍历删除等坑。
-
Java集合不可变设计旨在避免意外修改、提升可预测性与线程安全性;通过List.of()等创建真正不可变实例,防止跨模块误改、天然线程安全、增强函数式编程可靠性。
-
Java中用JarOutputStream打包JAR文件,本质是向ZIP流写入符合JAR规范的条目(JarEntry)并可选添加META-INF/MANIFEST.MF;必须显式设置JarEntry时间戳(如entry.setTime(System.currentTimeMillis())),否则部分JDK版本使用1980-01-01默认值导致解压失败;MANIFEST.MF必须作为第一个条目写入,即先putNextEntry(newJarEntry("META-INF/MANIFEST.MF"))再ma
-
异常链通过将底层异常作为原因嵌入新异常,实现错误信息的封装与追溯。在Java中,使用Throwable类提供的带cause参数的构造函数或initCause()方法,可在抛出业务异常时保留原始异常。例如,在Service层捕获SQLException后,可封装为UserServiceException并传入原异常,形成链条。打印堆栈时会自动显示“Causedby”层级结构,便于定位根因。自定义异常应提供publicMyException(Stringmessage,Throwablecause)构造函数并
-
Java项目通过SQLiteJDBC驱动实现本地数据存储,适合轻量级应用。1.添加Maven依赖引入sqlite-jdbc;2.使用DriverManager连接数据库文件,自动创建sample.db;3.执行建表、增删改查操作;4.推荐使用PreparedStatement防注入,try-with-resources管理资源,外部配置路径,注意并发写锁与定期备份,确保稳定运行。
-
双亲委派是类加载的向上委托责任链机制:AppClassLoader先委托ExtClassLoader,再委托BootstrapClassLoader,仅当顶层失败才自救加载;其核心在loadClass()三步逻辑,且打破需重写loadClass()而非仅findClass()。
-
PriorityBlockingQueue的出队方法有poll()、take()和remove():poll()非阻塞取头元素,空时返回null;take()阻塞等待直至有元素;remove(Objecto)按值删除首个匹配元素,时间复杂度O(n)。
-
Java多线程面试重在实战经验而非背诵;wait()必须在synchronized块中调用,否则抛IllegalMonitorStateException;ConcurrentHashMapJDK8用CAS+单桶锁替代分段锁;线程池拒绝策略中CallerRunsPolicy更防雪崩;ThreadLocal内存泄漏因key弱引用而value强引用未及时清理。
-
合理使用异常机制可提升Java程序健壮性。应区分IOException、Json解析异常、HTTP客户端/服务端异常及自定义异常,针对性捕获处理;避免泛化catch,逐层处理并转换为统一业务异常,封装上下文信息;结合重试与熔断机制控制外部风险,防止系统级联故障。
-
Arrays.asList()不能直接修改原数组,因其返回的是不支持add/remove的内部ArrayList;传入基本类型数组会因泛型擦除导致仅含一个元素。
-
LinkedHashMap通过双向链表维护插入或访问顺序,支持按插入顺序遍历,默认情况下新元素添加至链表尾部;当构造函数第三个参数为true时,启用访问顺序,每次get或put会将对应条目移至末尾,适用于LRU缓存;通过重写removeEldestEntry方法可实现容量控制,常用于需顺序一致的缓存、配置解析和序列化场景。
-
在SpringWebFlux应用中,将非响应式验证逻辑集成到响应式流中,并确保其异常能够被正确捕获和测试,是构建健壮API的关键。本文将深入探讨非响应式验证在响应式环境中的行为差异,并提供一种利用Mono.fromRunnable等操作符将此类验证无缝融入响应式流的解决方案,同时演示如何使用WebTestClient有效地进行单元测试,以确保异常处理的正确性。
-
ConcurrentHashMap通过CAS与synchronized实现高效线程安全,JDK8采用数组+链表/红黑树结构,读无锁、写锁单节点,支持高并发操作。
-
CountDownLatch通过计数器实现线程同步,主线程调用await等待,各任务线程完成时调用countDown,计数归零后主线程继续执行,适用于分批任务协调。
-
引入rocketmq-spring-boot-starter依赖,2.配置NameServer地址、生产者组名、消费者组名及相关参数,3.使用RocketMQTemplate实现消息发送,4.通过@RocketMQMessageListener注解创建消费者监听消息;SpringBoot整合RocketMQ的核心步骤包括引入依赖、配置参数、编写生产者和消费者代码,其中依赖管理简化了客户端配置,YAML配置文件定义了关键属性,生产者使用RocketMQTemplate发送消息,消费者通过注解声明监听逻辑并处