-
答案:通过定义Course类并利用LocalTime判断时间重叠,实现选课冲突检测。具体为创建包含课程信息的实体类,重写equals和hashCode方法,使用List存储已选课程,在添加新课时遍历列表调用isConflict方法判断是否同一天且时间区间重叠(startTime.isBefore(other.endTime)&&endTime.isAfter(other.startTime)),若冲突则提示用户无法添加,否则加入列表完成选课;可扩展支持单双周、课程编号及Web接口等功能。
-
ForkJoinTask是Java中用于高效并行计算的核心类,适合分治算法场景。通过继承RecursiveTask(有返回值)或RecursiveAction(无返回值),重写compute()方法实现任务拆分与执行,结合fork()异步提交、join()等待结果,利用ForkJoinPool的工作窃取机制提升多核性能,关键在于合理设置任务粒度以平衡拆分开销与并行效率。
-
抽象类该有构造函数,且通常必须有;它不能是private,推荐用protected修饰,子类构造器需显式调用super(...)。
-
应使用枚举配合switch实现状态分流,显式覆盖所有枚举值、禁用default兜底,Java14+推荐switch表达式,旧版default抛AssertionError;case仅调度不实现业务;状态变量须强类型绑定枚举;优先考虑在枚举内定义抽象方法实现行为穷尽。
-
Thread.enumerate()仅返回当前线程组活跃线程快照数组,需配合getState()逐个判断状态;统计时应先用activeCount()预估并扩容数组,再enumerate填充,遍历非null线程计数各State频次。
-
安全获取Stream首个元素应始终基于Optional的存在性做显式分支处理:用ifPresent()执行无返回操作,orElse()/orElseGet()提供默认值,map()+orElse()链式转换,orElseThrow()仅用于业务强制非空场景。
-
Optional.or()提供惰性、可组合的备选值获取机制,接收Supplier<Optional<T>>,仅在为空时调用并返回Optional,支持链式操作与多级fallback。
-
基本类型必须通过包装类才能存入Java集合,因集合只支持引用类型;自动装箱/拆箱简化操作,但需注意==比较陷阱、null值检查及字符串转换异常处理。
-
锁消除是JVM通过逃逸分析确认对象未逃逸后自动移除无竞争同步的操作。若对象仅在方法内创建使用、不被返回、不赋值给静态字段、不传入跨线程方法,则判定为线程私有,synchronized块被JIT直接删除;典型场景包括局部new的StringBuffer、ArrayList等;但对象赋值给static字段、作为返回值、进入全局容器或逃逸分析被关闭时,锁消除失效。
-
Future.get超时后任务仍在运行,必须手动调用cancel(true)中断;重试前需确保上轮任务终止,区分TimeoutException、ExecutionException和InterruptedException处理逻辑,并合理配置线程池。
-
ATM类设计需保证线程安全:账户余额用AtomicInteger或synchronized保护;Account与ATM解耦;余额操作返回boolean;避免在getter/toString中做业务判断;withdraw需严格参数校验。
-
直接继承InheritableThreadLocal无法实现写时复制,因其childValue()仅在子线程创建时调用一次且不拦截set();需用InheritableThreadLocal透传父线程快照、ThreadLocal管理本地值,并在set()首次调用时深拷贝快照完成按需复制。
-
CopyOnWriteArraySet不适合保护“配置数组列表”,因其是Set、去重无序,底层依赖CopyOnWriteArrayList导致写操作需全量复制数组;高频读+极少写时可凑合用,但推荐按场景选CopyOnWriteArrayList或不可变List。
-
并行流会加剧GC压力,因其将任务切分为多个ForkJoinTask,各线程在本地Eden区高频创建短命中间对象,导致Eden快速填满、MinorGC频次飙升。
-
调试时发现方法返回正确值,但赋值后的变量仍为初始值(如空字符串),根本原因常是调试器在跨线程执行时无法准确反映主线索引的最新变量状态,而非赋值本身失败。