-
FreeMarker模板中直接使用isXxx()方法名会导致“期望boolean却得到method+sequence”错误;应优先访问对应JavaBean属性(如xxx),或显式调用方法(isXxx())并加括号,确保获取返回值而非方法引用。
-
DCL在Java5前因volatile重排序约束弱易致“半初始化”;JDK5+需用volatile保证安全;推荐静态内部类方案,线程安全、延迟加载、无同步开销。
-
final修饰变量时引用不可变但对象状态可变,修饰方法时禁止重写但允许重载,修饰类时禁止继承且字段需显式final才不可变,其初始化安全性保障多线程下final字段的正确可见性。
-
什么时候该用CyclicBarrier而不是CountDownLatch当你需要多个线程反复在某个点同步、等彼此都到达后再一起往下走,就该选CyclicBarrier;CountDownLatch是一次性倒数,用完就废,没法重用。典型场景:分段计算后汇总结果(比如4个线程各自处理一批数据,算完必须等齐了再合并统计),且这个“分段→等待→合并”流程要跑好几次——这时候CyclicBarrier的可重用性才是关键。CyclicBarrier构造时指定参与线程数,到达的线程调用aw
-
ServiceLoader通过读取META-INF/services/下以接口全限定名命名的文本文件来加载实现类,文件每行一个实现类全限定名,需严格匹配包名和大小写;load()仅解析配置,next()才触发Class.forName和实例化,使用线程上下文类加载器,默认非单例。
-
最常见原因是未正确配置spring-boot-maven-plugin或继承了非SpringBoot的parent;若用自定义parent必须显式声明该插件,否则仅生成普通jar,无BOOT-INF和Main-Class,无法java-jar运行。
-
对象创建始于new指令,JVM先加载类到方法区并生成Class对象;随后在堆中分配内存,采用指针碰撞或空闲列表策略,取决于垃圾回收器和内存整理情况;为保障线程安全,优先使用TLAB实现线程私有分配,不足时通过CAS重试保证原子性;对象内存布局由对象头、实例数据和对齐填充组成,包含哈希码、锁状态、字段值等信息,并按8字节对齐;最后设置对象头并执行构造函数完成初始化,整个过程由JVM高效管控。
-
怎么让SonarQube扫描到你的Java项目源码SonarQube默认不会自动发现pom.xml或src/main/java,它只认你明确告诉它“从哪扫”“用什么编译器”。常见现象是扫描后显示0行代码、java.lang.NoClassDefFoundError、或者连src目录都不出现在文件列表里。必须在项目根目录下运行扫描命令,且该目录要包含pom.xml(Maven)或build.gradle(Gradle)用sonar-scanner时,显式指定-Dso
-
renameTo返回false的主因是目标文件存在、跨分区、权限不足或父目录不存在;listFiles返回null需先校验exists()和isDirectory();推荐用Files.move替代renameTo以获得明确异常。
-
var仅限方法体内局部变量声明,需初始化且类型可静态推断,禁用于字段、参数、返回值及lambda形参;推断类型最具体但可能丢失泛型信息,影响可读性与维护性。
-
密封类用于定义受限几何图形体系,编译期封禁外部扩展、限定子类型集合,配合伴生对象工厂方法、when穷举匹配与不可变dataclass保障类型安全与状态一致性。
-
正确重写equals和hashCode需遵守自反性、对称性、传递性、一致性和非空性;先判断引用是否相同,再通过instanceof检查类型并比较关键字段;若重写equals则必须重写hashCode,确保相等对象具有相同哈希码,通常用31乘以各关键字段哈希值累加,以提升哈希表性能。
-
不该。Java中用异常控制业务流程会模糊错误语义、降低性能、增加理解成本;仅当发生真正意外(如连接断开)或违反契约(如传null)时才用异常,其余应使用Result等明确返回类型封装状态。
-
Java实现邮件发送依赖JavaMailAPI,通过引入javax.mail或jakarta.mail依赖,配置SMTP服务器信息(如QQ邮箱smtp.qq.com:587),使用授权码认证,创建Session和MimeMessage对象,设置发件人、收件人、主题及内容,调用Transport.send()发送;支持文本、HTML格式及附件,适用于通知、验证等场景。
-
泛型类通过类型参数实现类型安全的代码复用,如Box<T>可指定T为String等具体类型;泛型方法在声明中引入类型参数,如printArray<T>(T[]array)可处理不同类型的数组;Java泛型通过类型擦除实现,运行时泛型信息被擦除,导致不能newT()或使用instanceof检查泛型类型;通配符?配合边界extends和super限制类型范围,提升API灵活性与安全性。掌握泛型需多练习定义与使用类型参数。