-
next()和nextInt()不消费换行符,导致后续nextLine()读到空字符串;应加scanner.nextLine()清理或统一用nextLine()转换;nextInt()遇非数字抛异常且卡住,需hasNextInt()预判或捕获后next()清除;next()读单词,nextLine()读整行;Scanner关闭后不可恢复,建议全局单例。
-
答案:验证Java程序跨平台运行需确保JDK版本一致、使用标准路径处理、在多系统真实环境测试并结合自动化流程。具体包括:统一JDK版本并避免非标准API;采用File.separator和Paths.get()处理路径;通过ClassLoader读取资源并指定字符集;在Windows、Linux、macOS部署测试JAR包运行情况;提供平台适配的本地库;利用CI工具实现多系统自动化测试,确保程序稳定性。
-
StringRedisTemplate.opsForValue()存不进数据最常见原因是未调用set()或连接/配置错误;set()是同步的,需检查Redis连通性、序列化器(应使用StringRedisSerializer)、键过期设置及是否误用RedisTemplate。
-
Java类单继承且不可继承final类;私有成员存在但不可见;@Override是编译期契约,防止重写失效;多态仅适用于非static、非final、非private的实例方法,调用由运行时类型决定。
-
finally不会运行,因为System.exit(0)直接终止JVM,跳过所有未执行字节码(包括finally),这是JVM规范行为,非bug。
-
System类是Java中不可实例化的静态工具类,用于系统交互,提供标准I/O流、时间获取(currentTimeMillis()和nanoTime())、数组操作等核心功能。
-
Semaphore的核心作用是限制并发数而非保证线程安全;它通过acquire/release控制资源配额,需成对调用且置于finally块;公平模式启用FIFO排队防饥饿但性能略低;acquire(n)要求原子性扣减n个许可。
-
异常传递机制指Java中未捕获的异常沿调用栈向上传播,直至被处理或程序终止。1.方法内抛出异常后,若无匹配catch块,则自动向上抛;2.受检异常需显式try-catch或throws声明;3.可通过异常链包装底层异常,保留原始信息;4.finally块始终执行,但其抛出的异常会覆盖原异常,建议避免在其中抛异常。掌握该机制有助于提升代码健壮性与可维护性。
-
Map.values()返回的是Collection而非List,它是底层Map的值视图,不支持随机访问和排序,修改会影响原Map,遍历时并发修改会抛ConcurrentModificationException。
-
Java中用数组实现0-1背包问题的核心是构建二维dpi矩阵,表示前i个物品、容量w下的最大价值;初始化dpn+1,首行首列置0;按状态转移方程逐行填表;可回溯选中物品;还可优化为一维滚动数组。
-
应排除spring-boot-starter-data-neo4j,显式引入版本对齐的neo4j-ogm-core、api与driver(如3.2.31),HTTP驱动URI须为http://或https://,配置credentials认证,@Property标注字段,用包装类,load时指定depth=0,批量操作用saveAll。
-
Collections.disjoint采用短路逻辑遍历小集合并调用大集合的contains,不构造中间交集,最坏时间复杂度O(m×n),但平均优于先求交集再判空;要求集合非null,支持不可变集合;使用前需判空,性能敏感场景下通常无需替换,底层实现比方法选择更重要。
-
答案:基于用户行为的协同过滤通过计算用户间余弦相似度,找出相似用户并推荐其高分未读图书。例如,系统为Alice推荐Bob和Charlie评分较高的《深入理解计算机系统》,因二者与Alice阅读偏好相似且该书未被Alice评过分。
-
BitSet比boolean[]省内存因用1bit存布尔值,而boolean[]按字节对齐致空间放大8倍;适合稀疏布尔标记,但get/set略慢、不支持泛型;底层为long[],扩容翻倍,初始化建议预设大小;遍历用nextSetBit()高效跳零;跨系统需注意字节序与padding。
-
Java中括号匹配与中缀转后缀均依赖栈的LIFO特性:括号匹配通过入栈左括号、遇右括号校验并弹出实现;ShuntingYard算法依运算符优先级控制入栈/弹出,生成后缀表达式;后缀求值则用栈执行数字入栈、运算符弹双操作数计算。