-
IDEA中PlantUML插件失效主因是Graphviz未配置PATH或Java版本与插件不兼容,需确保dot命令可用、使用0.36+插件适配JDK17+,并手动指定最新plantuml.jar路径,且仅对有效.java文件生效。
-
Semaphore用于限制并发访问资源的数量,如停车场示例中控制5个停车位的分配,通过acquire获取许可、release释放许可实现限流;CountDownLatch用于等待一组操作完成,如主线程等待3个子任务执行完毕后再继续,通过countDown递减计数、await阻塞等待归零。两者均属于java.util.concurrent包,适用于不同协作场景:前者适合资源池管理,后者适合任务同步,结合ExecutorService可更好管理线程生命周期,合理选用可简化并发逻辑。
-
Java的interrupt()仅设中断标志位,对阻塞线程需配合可中断方法(如sleep/wait)响应InterruptedException才能优雅中断;不可中断场景须用可中断替代方案或关闭资源破局。
-
AbortPolicy是默认拒绝策略,任务被拒时直接抛出RejectedExecutionException异常;CallerRunsPolicy则由提交任务的线程同步执行该任务,实现反压节流。
-
StackOverflowError是JVM运行时错误,因线程调用栈深度超限导致;常见于无终止条件的递归、隐式循环调用或toString等方法中自引用;典型特征是堆栈跟踪大量重复行;解决需修复逻辑而非盲目调大-Xss。
-
JavaRecord的Lombok@With注解默认只生成单字段with方法,但可通过链式调用组合多个单字段方法实现多字段更新;无需生成冗余的复合方法,既保持API简洁性,又兼顾灵活性与可维护性。
-
线程池是高并发Java应用的基础设施,可避免线程频繁创建销毁的性能损耗、防止线程数量失控导致系统崩溃、提供统一调度与任务治理能力,并符合工程规范与可维护性要求。
-
Callable是能返回结果并抛出受检异常的函数式接口,必须配合ExecutorService使用,不能直接传给Thread;其返回值由泛型指定,通过Future.get()获取结果,但会阻塞线程。
-
合理选择同步对象,避免过度同步和死锁,注意可见性与原子性,使用恰当工具可提升并发程序的稳定性与性能。
-
RecyclerView删除功能仅触发一次,根本原因在于addItem时重建了Adapter却未重新设置点击监听器;正确做法是复用原Adapter并调用notifyItemInserted()等标准刷新方法。
-
JDK8已无任何权威安全支持,风险极高;推荐务实升级至JDK17(SpringBoot3基线,GC与容器支持稳定)或JDK21(最新LTS,含虚拟线程等新特性),但须避免跳过JDK17直升JDK21。
-
ReentrantLock需手动配对acquire/release,必须用try-finally确保unlock;默认非公平锁性能更优;Condition替代wait/notify须用while重检条件;仅在需超时、中断响应或多个条件队列时选用。
-
List与数组转换需注意类型安全与可变性:1.List转数组推荐使用toArray(newT[0])避免强转异常;2.数组转List用Arrays.asList()但生成不可变列表,如需修改应包装为newArrayList<>(...);3.基本类型转换需借助StreamAPI,如int[]与List<Integer>通过boxed()和mapToInt()实现。
-
配置Scala与Java混合开发环境的关键是安装JDK、Scala并统一管理依赖。1.安装JDK8或11,配置JAVA_HOME和PATH;2.安装Scala并设置SCALA_HOME;3.使用SBT创建项目,配置build.sbt,组织src目录;4.在IntelliJIDEA中安装Scala插件并导入SBT项目,实现Java与Scala互调。
-
观察者模式解决对象间一对多依赖更新,核心是状态变更通知;策略模式解决算法动态替换,核心是算法可插拔。二者职责分明,可组合使用但不可混淆边界。