-
HashSet是去重首选,O(1)时间复杂度,不保证顺序,依赖hashCode()和equals(),允许一个null,线程不安全;LinkedHashSet保持插入顺序,开销略高;TreeSet支持排序,O(logn),基于红黑树;Stream.distinct()底层用LinkedHashSet,语法糖。
-
面向接口编程的本质是“换实现不改调用方”,即通过声明接口类型(如List、UserService)而非具体实现类,使底层实现可替换而不影响调用方代码,适用于多实现或需模拟/隔离测试的场景,避免硬编码实现导致的耦合与维护风险。
-
TreeMap默认按键的自然顺序排序,要求键实现Comparable接口。使用String或自定义类(如Person)作为键时,只要实现compareTo()方法,插入后遍历即为有序结果,且键不能为null。
-
在SpringBoot3中测试无@SpringBootApplication的独立JPA库时,应使用@DataJpaTest并嵌套一个空的@SpringBootApplication配置类,以触发SpringBoot自动配置机制,从而正确加载Repository和TestEntityManager。
-
Java内存模型(JMM)是定义多线程下变量可见性、有序性及重排序规则的抽象规范,非物理内存布局;其核心为“主内存-工作内存”模型,通过volatile、synchronized和final提供不同强度的内存语义保障。
-
本文详解如何基于PDFBox高精度解析带表格结构的PDF文件,并导出为格式规范的Excel(.xlsx),准确还原列宽、行结构及空单元格,彻底解决传统文本提取导致的列错位问题。
-
答案:通过定义加减乘除静态方法并处理除零异常,结合Scanner实现交互式计算,提升代码可读性与复用性。
-
Java方法参数传递只有值传递,基本类型传递数值副本,引用类型传递地址副本,修改参数不影响原变量或原引用指向。
-
Collections.sort()要求List元素实现Comparable或传入Comparator,仅支持List且不返回新集合;Stream.sorted()创建新集合;TreeSet/TreeMap天然有序但相等性依赖compareTo而非equals。
-
封装的核心是接口与实现分离,而非仅用private修饰符;它要求外部仅通过稳定接口操作,无需知晓内部存储、计算或状态维护细节,如BankAccount的deposit()和getBalance()方法。
-
happens-before是一组显式定义的偏序规则,用于判断操作可见性与重排序约束;它不是时间先后关系,也不保证代码顺序即执行顺序。
-
实现克隆需实现Cloneable接口并重写clone()方法,1.默认为浅克隆,仅复制基本类型和引用地址;2.深克隆需手动复制引用对象;3.推荐使用拷贝构造函数或序列化替代以避免问题。
-
订单支付与退款流程需确保数据一致性和安全性。1.创建订单并调用支付网关获取prepay_id,返回前端参数调起支付控件;2.支付成功后,第三方异步回调notify_url,验证签名并更新订单状态为“已支付”;3.退款时校验订单状态,调用退款接口并记录退款流水,支持退款结果通知解密与状态更新;4.通过异常处理、分布式锁、日志记录、定时对账和权限控制保障系统稳定与安全。
-
<p>TreeMap默认按键的自然顺序排序,可通过构造函数传入Comparator自定义排序规则。例如字符串可按长度排序:TreeMap<String,Integer>map=newTreeMap<>((s1,s2)->s1.length()-s2.length());对自定义对象如Person可按年龄排序:TreeMap<Person,String>map=newTreeMap<>((p1,p2)->Integer.compare(
-
字符串常量池的主要作用是优化字符串存储和重用,节省内存并提高性能。JVM通过确保相同字符串字面量在内存中只存在一份拷贝来实现这一目标。当使用字符串字面量时,JVM首先检查常量池是否存在该字符串,存在则返回引用,不存在则创建并加入池中。String的intern()方法可手动将字符串加入常量池并返回其引用。不同JDK版本中,字符串常量池位置有所变化:JDK1.6及之前位于永久代,JDK1.7移至堆中,JDK1.8后堆中依旧保留。字符串拼接方式影响常量池使用,字面量拼接在编译期优化入池,变量拼接需手动调用in