-
在MapStruct中,当使用多参数映射方法时,需通过source属性显式指定参数名,而非qualifiedByName(后者仅用于调用自定义命名转换方法),才能将额外参数准确映射至嵌套目标字段(如content.shortText)。
-
答案是:Java时区问题需从系统、JVM参数和代码三方面解决;JVM默认继承操作系统时区,跨平台易偏差;应通过-Duser.timezone=Asia/Shanghai设置启动参数,或在代码中调用TimeZone.setDefault()统一时区;推荐使用java.time包并显式指定ZoneId,避免SimpleDateFormat等旧类;数据库连接需配置serverTimezone参数;关键是在入口处统一设置,确保全链路时区一致。
-
Java中日志与异常需互补:异常负责结构化错误传播,日志负责记录可追溯的上下文;底层异常不重复打日志,上层捕获后结合业务场景记录WARN/ERROR并带堆栈;日志须含业务动作、关键输入(脱敏)、完整堆栈;按故障严重性分级,杜绝空catch、拼接异常等反模式。
-
使用DocumentBuilder.newDocument()创建空XML文档后,getDocumentElement()必然返回null,因为此时文档尚未包含任何元素;必须先通过doc.appendChild(element)显式添加根元素,才能获得有效的文档根节点。
-
JVM堆内存分代管理,非连续空间:YoungGen(Eden、S0、S1)、OldGen和Metaspace;对象优先分配Eden,触发MinorGC后存活对象复制或晋升,大对象可直接入OldGen;字符串字面量存常量池,newString("abc")仅在堆建引用对象;AllocationFailure是GC正常触发提示,非OOM;逃逸分析可能使对象栈上分配。
-
Java定义常量的核心方式是publicstaticfinal修饰符组合,配合全大写下划线命名;需在声明时或静态代码块中初始化;接口中默认字段为publicstaticfinal但不推荐;枚举更适合类型安全、具行为的常量场景。
-
Java内存模型(JMM)是一套关于共享变量读写行为的语义规范,规定线程间修改如何可见;其通过主内存与工作内存的交互流程引发可见性问题,volatile可解决可见性与有序性但不保证原子性,happens-before是判断操作顺序的唯一可靠依据。
-
ClassNotFoundException发生在类路径缺失、类名错误或依赖未引入时,需通过try-catch捕获并结合日志、默认实现或SPI机制提升动态加载稳定性。
-
ConcurrentLinkedDeque是Java中线程安全的非阻塞双端队列,基于链表结构和CAS操作实现,支持高效并发插入与删除,适用于多线程环境下的队列、栈及工作窃取场景,具备弱一致性迭代器且允许null元素,但应避免频繁调用size()及contains等遍历方法以保障性能。
-
Semaphore通过许可机制控制并发线程数,常用acquire()和release()方法实现限流,如限制3个线程同时执行任务,适用于资源池管理、接口限速等场景,需注意及时释放许可并合理设置许可数量。
-
Java跨平台一致性由JVM规范、字节码抽象性、验证机制和TCK测试四层机制保障:字节码面向JVM抽象结构而非硬件;JVM规范精确约束每条指令语义;类加载时Verification阶段强制检查字节码合法性;厂商实现必须通过TCK测试验证指令行为符合规范。
-
捕获Exception本身不是坏习惯,但不加区分地捕获会掩盖编程错误、干扰异常语义、误吞关键异常并导致日志失真;应优先捕获具体异常,仅在顶层兜底或特殊场景下谨慎使用。
-
try-with-resources的核心目的是将“必须做但容易忘”的资源关闭变为自动完成,通过JVM保障异常下释放、逆序关闭多资源、抑制关闭异常以保主错不丢。
-
Java递归遍历目录查文件推荐用Files.walk()(Java8+),简洁线程安全;兼容旧版可用File.listFiles()手动递归,需判空、校验可读性及目录类型,并支持名称匹配、扩展名过滤、内容搜索,注意防符号链接循环、异常捕获与性能优化。
-
String.replace()按字面量替换,replaceAll()走正则引擎;前者安全简单,后者需转义且易误匹配;大量替换用StringBuilder,复杂规则复用Pattern;注意null判空、不可变性及Unicode代理对处理。