-
答案:通过SimpleDateFormat解析时间字符串并转换为Date对象,结合当前时间计算毫秒差并换算为分钟,判断是否在10分钟内触发提醒;使用ArrayList管理多个日程,遍历并检查未提醒且接近时间的事件输出提示;需处理ParseException异常并注意输入格式一致性,推荐后续升级至Java8的LocalDateTime以提升线程安全与时区处理能力。
-
SonarLint在IntelliJ中未响应,主因是未绑定项目、Java语言支持未启用或sonar.java.binaries/sourcePaths路径配置错误;需检查项目导入状态、SDK配置、手动设置二进制与源码路径,并启用语义分析规则。
-
Java普通方法调用开销大,需保存PC、压栈、传参、跳转、执行、弹栈、恢复上下文;add(inta,intb)类方法调用开销常超总耗时60%,虚方法因查vtable等更慢。
-
Java中try-catch应只包裹明确可能抛异常且能处理的代码,避免过大或过小;受检异常必须处理,非受检异常慎用throws;日志需用SLF4J记录完整上下文并脱敏;自定义异常依是否强制调用方处理选择继承Exception或RuntimeException。
-
wait()释放锁且需notify唤醒,sleep()不释放锁且超时自动恢复;前者用于线程协作,后者用于定时暂停。
-
应统一使用java.time包计算时间差:用Duration.between()处理Instant或LocalTime,Period.between()处理LocalDate或LocalDateTime;注意时区转换、单位语义区分及DateTimeFormatter大小写敏感问题。
-
静态方法不能被重写,只能被隐藏;JVM在编译期根据引用类型静态绑定,与实际对象类型无关,故Parentp=newChild();p.staticMethod()调用Parent的版本。
-
WorkStealing在ForkJoinPool中通过双端队列实现:线程本地LIFO操作(队尾),偷任务时FIFO从他人队列队首取,避免伪共享;仅适用于无状态、CPU密集型可拆分任务,粒度建议>100μs。
-
<p>用Math.random()做权重抽奖总抽不到低概率奖品,因其返回[0,1)导致最后一区间长度缺失;正确做法是预计算前缀和,用Math.random()*totalWeight后二分查找。</p>
-
相同单词未合并是因为未统一大小写、未清除标点及空格残留,导致“Hello!”与“hello”等被视为不同键;需toLowerCase()、正则清理、判空后计数,并慎用Scanner分隔符。
-
JNA比JNI更适合纯Java项目调用本地库,因其无需编写C头文件、编译或打包.so/.dll,仅需Java接口+注解即可运行时自动解析符号;但要求函数签名严格匹配,存在性能开销与内存控制限制。
-
不建议用异常控制正常业务流程,因性能开销大、掩盖设计问题;应将可预期失败转为返回值或状态码,异常仅用于真正意外场景,并需分层定义、规范日志与处理。
-
推荐使用Objects.isNull(str)||str.isBlank()(Java11+)或StringUtils.isBlank(str)(Java8),二者均安全、简洁且正确识别null、空字符串及全空白字符,避免NPE与逻辑空遗漏。
-
泛型类通过类型参数实现类型安全的代码复用,如Box<T>可指定T为String等具体类型;泛型方法在声明中引入类型参数,如printArray<T>(T[]array)可处理不同类型的数组;Java泛型通过类型擦除实现,运行时泛型信息被擦除,导致不能newT()或使用instanceof检查泛型类型;通配符?配合边界extends和super限制类型范围,提升API灵活性与安全性。掌握泛型需多练习定义与使用类型参数。
-
Collectors.toList()返回可变ArrayList,支持重复和null;toSet()返回无序去重Set,遇null抛NPE;toMap()遇重复key抛DuplicateKeyException;joining()遇null直接抛NPE;应依约束选方法。