-
反射调用接口默认方法必须使用实现类的Class对象而非接口Class,因JVM禁止在接口类型上调用invokeVirtual;需用getDeclaredMethod获取方法,传入实现类实例调用,且无需setAccessible(true)。
-
只重写equals会导致HashSet找不到对象,因为HashSet先用hashCode定位桶再用equals比对;若逻辑相等的对象哈希值不同,就会散列到不同桶中,造成contains返回false、add重复对象成功等现象。
-
ZXing默认黑底白图是因MatrixToImageWriter将0当白色、1当黑色,与内部0表空白/1表墨点逻辑相反;应显式传入MatrixToImageConfig(Color.BLACK.getRGB(),Color.WHITE.getRGB())。
-
应采用类型驱动设计:questionType区分题型,答案统一存String/JsonNode;Question用surveyId外键;JPA用LEFTJOINFETCH避免N+1;DTO接收答案并用@JsonAnySetter;选项与答案分表存储。
-
Future.get()阻塞是基于AQS的挂起唤醒机制,非busy-wait;通过LockSupport.park()使线程进入WAITING状态,不消耗CPU;支持中断和超时控制,多线程调用安全,但需防资源泄漏与级联故障。
-
自定义异常应以Exception结尾、使用驼峰命名法并确保语义明确,如InvalidUserException,避免模糊名称如MyException,便于识别和维护。
-
Java命令找不到的主因是JDKbin目录未加入PATH或PowerShell别名冲突;需先用Get-Command验证、检查PATH路径、删除java别名,并重启PowerShell生效。
-
答案:通过校验索引范围、使用增强for循环、异常捕获和空数组检查可有效避免数组下标越界异常。具体包括:1.访问前检查0≤index<array.length;2.遍历时优先使用for-each循环;3.用try-catch处理不可预知索引;4.初始化前检查数组非空,提升代码健壮性。
-
JDK17是当前最稳妥的生产基线,因其LTS成熟度高、主流框架适配稳定;应避免使用模糊镜像标签如“openjdk:17”,优先选用明确版本和OS的镜像如“openjdk:17-jre-slim-bullseye”,并注意JAVA_HOME、时区、编码及JVM参数配置。
-
能,Java9+接口中支持private方法,用于复用default或static方法的公共逻辑,避免重复代码,但不可被实现类访问或重写,且不能与static同时使用。
-
Java日程提醒核心是可靠触发、时间准确、防重复,首选ScheduledExecutorService;需正确计算首次延迟、保存ScheduledFuture用于取消、解析自然语言时间、落地通知方式并持久化未触发任务。
-
ServiceLoader加载不到实现类主因是META-INF/services位置错误或接口全限定名拼写错误;必须置于classpath根目录(如Maven的src/main/resources/META-INF/services/),文件名须为接口全限定名,内容为实现类全名,且实现类需有public无参构造器;Java9+模块化需在module-info.java中声明provides;其核心价值在于编译期解耦,运行时动态加载,支持插件扩展与多实现共存,但无优先级、条件加载等高级能力。
-
嵌套结果性能更好、N+1问题更少,但需手动对齐字段别名;嵌套查询适合复用SQL、逻辑隔离强的场景。
-
MyBatisGenerator默认不生成Mapper接口方法,因targetRuntime默认为MyBatis3;应改为MyBatis3Simple或MyBatis3DynamicSql,并注意驱动版本、驼峰映射、插件绑定等配置。
-
子线程未捕获异常不会被主线程try-catch捕获,只能通过Thread.UncaughtExceptionHandler处理;线程池需自定义ThreadFactory设置handler;Callable配合Future.get()可同步感知检查异常,但RuntimeException仅被包装为ExecutionException。