-
Callable与Runnable的核心区别在于:Callable的call()方法可返回泛型结果并抛出受检异常,而Runnable的run()方法返回void且不能抛受检异常;因此Callable配合Future才能实现异步结果获取。
-
该用静态还是非静态取决于访问需求:需访问外部类实例成员则用非静态,仅用静态成员或工具功能则优先static,以避免内存泄漏、支持序列化并提升性能。
-
Arrays.asList()返回固定长度List,不可增删;因其实现类未重写add/remove,调用抛UnsupportedOperationException;基本类型数组会被整体当作单个元素,应改用包装类型或Stream处理。
-
构造方法确保对象创建时初始化完整,通过赋值、参数校验、资源准备等操作使对象处于可用状态,支持重载以适应不同初始化场景,并可通过访问修饰符控制实例化方式,提升封装性与安全性。
-
final修饰引用类型锁住的是引用本身而非对象内容:变量地址不可变,但可通过引用修改对象内部状态;要真正不可变需类自身设计配合。
-
答案:Java反射调用构造函数时需处理ClassNotFoundException、NoSuchMethodException、InstantiationException、IllegalAccessException和InvocationTargetException;示例代码展示逐层捕获异常并处理私有构造函数的访问问题,确保程序健壮性。
-
Weka在对文本数据进行StringToWordVector转换后生成稀疏ARFF文件时,若样本类别值(如"Positive")位于属性列表首位且该样本在对应词向量中无非零项,该标签将被省略——这是稀疏格式的标准行为,并非数据丢失或处理错误。
-
comparingLong比comparing更适合long类型,因其避免自动装箱、零内存开销、无空指针风险(函数不返回null时),且要求getter返回primitivelong;若返回Long则编译失败,需改用comparing+Long::longValue或null安全方案。
-
使用ScheduledExecutorService可实现任务延时或周期执行,并复用线程池资源。通过newScheduledThreadPool创建,支持schedule、scheduleAtFixedRate和scheduleWithFixedDelay三种调度方式。需调用shutdown()关闭线程池,配合awaitTermination确保优雅停机,紧急时用shutdownNow()。自定义ThreadFactory可提升线程名可读性便于调试。任务内需捕获异常防止调度终止,避免长任务影响调度精度,耗
-
ZooKeeper通过临时顺序节点和Watch机制实现分布式锁,客户端在锁路径下创建临时顺序节点并判断是否为最小序号,若是则获得锁,否则监听前一节点删除事件以实现公平、可靠的锁竞争与自动释放。
-
final类禁止继承,编译期报错;final方法禁止重写,保障关键逻辑不被修改;二者语义独立,不影响内部成员可变性,也不提供线程安全。
-
答案:该打卡应用通过User、Record和AttendanceService类实现用户登录、每日打卡及记录查看功能,使用HashMap在内存中存储数据,结合LocalDate判断是否重复打卡,通过Scanner提供控制台菜单交互,适合Java初学者练手。
-
exceptionally仅捕获上游异常,不处理null等业务失败值;handle则统一响应成功与异常,需手动判空,且其中抛异常会传播,而exceptionally中抛异常会被吞掉。
-
AssertJ提供了强大的递归比较功能,支持通过字段名或正则表达式全局忽略嵌套对象中的特定字段(如id),从而避免手动处理多层JPA实体关系时的ID冲突问题。
-
Future.get()会阻塞,推荐用带超时的get(timeout,unit)避免无限等待;isDone()+get()存在竞态问题,应避免;cancel(true)不保证立即停止线程,需任务主动响应中断;原生Future无回调能力,复杂异步应使用CompletableFuture。