-
答案:Java中使用BufferedReader读取文件高效,需通过FileReader或InputStreamReader创建实例,推荐用try-with-resources管理资源,注意编码设置以避免乱码。
-
Jackson的YAMLMapper默认不将点号(.)视为路径分隔符,而是将其作为普通键名的一部分;若YAML中使用formatting.template这类扁平键,需配合JSONPointer/formatting.template而非/formatting/template才能正确定位。
-
应使用double而非float存储身高体重,因float在常见范围内易精度丢失导致BMI判断失败,且Java默认浮点类型为double,混用会引发隐式转换风险;BMI计算需确保单位统一、校验正数输入,并避免硬编码平方或误用Math.sqrt()。
-
Java中接口支持多继承,通过extends可扩展多个接口。例如MoveableextendsFlyable,Swimmable,实现类Duck需实现所有方法;若default方法冲突,必须重写解决;同名常量应通过接口名明确引用,避免歧义。
-
使用java.awt.Robot模拟文件上传后键盘失灵(如Ctrl键常驻触发),根本原因是按键按下后未对应释放,导致系统级按键状态异常,需严格配对keyPress()与keyRelease()。
-
ConcurrentHashMap可实现线程安全简易缓存,支持原子操作如computeIfAbsent,适合静态数据;需手动管理过期与清理,不自动回收;Weak/SoftReference不适用因不可控且非线程安全;LinkedHashMap非线程安全且无TTL;复杂场景应选Caffeine。
-
Java死锁典型场景包括:①多线程以不同顺序获取同一组Lock或synchronized对象,如银行转账中线程A先account1后account2、线程B反之;②嵌套同步且锁对象不一致。
-
并发是程序能同时管理多个任务,即使单核也靠时间片切换实现;并行需多核硬件支持,真正物理同时执行。Java中应优先用ExecutorService线程池而非裸Thread,并注意parallelStream()共享ForkJoinPool的风险。
-
IntelliJIDEA解压即用,需配置JDK11+并新建Java项目验证:下载压缩包→解压至英文路径→运行bin/idea.exe或idea.sh→在ProjectStructure中添加JDK→新建项目运行HelloWorld成功即配置完成。
-
SpringBoot使用SpringDataRedis时,CrudRepository对boolean类型字段(如isActive)的派生查询(如findAllByActiveFalse())常因序列化/反序列化不一致而返回空结果;根本原因是Redis存储的布尔值被序列化为字符串"true"/"false",但默认查询仍按boolean类型匹配,导致类型不匹配。
-
学生类和课程类应作为独立实体设计,通过Enrollment关系类建模多对多关联;ID统一用String;选课需校验存在性、重复性、容量等;退课与查询应维护courseToStudents、studentToCourses等内存索引以实现O(1)操作。
-
Callable和Future用于Java异步编程,Callable的call()方法可返回结果并抛出异常,Future用于获取异步任务结果及管理状态,需通过ExecutorService提交任务获取Future对象,调用get()阻塞获取结果,建议设置超时避免无限等待,注意处理ExecutionException并及时关闭线程池。
-
选择ThreadLocalRandom因其基于ThreadLocal为每个线程提供独立实例,避免同步开销,实现无锁、高性能的随机数生成,适用于高并发场景。
-
答案:安全遍历线程安全队列需根据集合类型选择策略。1.使用CopyOnWriteArrayList可获迭代快照,适合读多写少;2.ConcurrentLinkedQueue迭代器弱一致性,不保证实时性,禁止遍历时修改;3.可复制队列内容到本地集合遍历,但存在性能开销;4.阻塞队列推荐drainTo批量处理,保证原子性。应依据读写频率、实时性需求选择合适方式,避免并发修改导致不一致。
-
依赖倒置原则通过抽象解耦高层与低层模块,2.使用接口定义行为契约并借助构造函数注入实现依赖反转,3.结合Spring等框架自动装配提升灵活性,4.增强可测试性与扩展性,实现松耦合设计。