-
DelayQueue是基于PriorityQueue和ReentrantLock实现的无界阻塞队列,元素须实现Delayed接口,按剩余延迟时间小顶堆排序,仅当getDelay(TimeUnit.NANOSECONDS)≤0时可被取出。
-
Java中FileVisitor遍历目录树的核心是Files.walkFileTree()配合自定义访问器,实现深度优先、安全可控的遍历;其接口含preVisitDirectory、visitFile、visitFileFailed、postVisitDirectory四个关键回调方法,分别对应目录进入前、文件访问时、访问失败时、目录退出后四种状态。
-
Map的key必须重写equals()和hashCode(),因哈希表靠hashCode()定位桶、equals()判断键等价;若不重写,默认地址比较会导致相同逻辑对象被误判为不同key。
-
泛型擦除后ArrayList<String>和ArrayList<Integer>运行时均为ArrayList。Java泛型是编译期特性,字节码无类型参数,JVM无法区分具体类型,故不能用于运行时类型判断或分支逻辑。
-
使用StreamAPI的map方法可高效提取对象集合字段,如Listnames=users.stream().map(User::getName).collect(Collectors.toList()),支持字段转换、组合及null值处理,代码简洁且功能强大。
-
答案:系统实现候选人管理与投票功能,通过类设计和集合操作完成添加、投票、排序等核心逻辑。
-
Java中Stream.sorted()用于排序,不改变原数据,返回新流。支持自然排序与自定义比较器,可实现单级、多级及逆序排序,常用于基本类型、字符串和对象列表,需结合终端操作触发执行。
-
Java中通过Scanner类实现输入,System.out实现输出。导入java.util.Scanner后创建Scanner对象读取键盘输入,使用nextLine()、nextInt()等方法获取字符串、整数等数据;输出则用System.out.println()换行输出,print()不换行输出,printf()格式化输出。注意读取数值后接nextLine()需吸收换行符,并在最后调用scanner.close()释放资源。结合二者可完成用户交互程序,如信息录入,关键在于类型匹配与输入顺序正确。
-
组合关系是Java中强拥有、同生命周期的“整体-部分”关联,部分由整体创建并随其销毁,UML用实心菱形表示;它不同于聚合(弱拥有)和继承(is-a),应优先选用以降低耦合、提升灵活性。
-
在Groovy中,若需根据字符串拼接出变量名并获取其值(如"${CODEBASE}_sonar_binaries"),不能直接用"${...}"插值访问局部变量;必须通过this."variableName"访问脚本级或对象属性级变量,或改用Map统一管理变量。
-
观察者模式与事件机制本质相同,均实现对象间松耦合通信。被观察者状态变化时通知所有观察者,形成“一对多”依赖。Java中通过Observable与Observer接口实现,后被事件机制扩展,引入事件源、事件对象和监听器,广泛应用于GUI与事件驱动系统。现代Java推荐使用函数式接口或响应式编程替代过时的Observable,提升类型安全与异步处理能力。
-
JMM是多线程通信的抽象规则,定义主内存与工作内存间变量可见性;JVM内存结构是运行时真实分区,包括堆、元空间、栈等,OOM和GC均发生于此。
-
答案:该记账本应用通过Entry类定义收支条目,AccountBook类实现添加、查看和统计功能,使用ArrayList存储数据,支持控制台交互操作,并可扩展文件持久化。
-
最常用方式是使用Jackson或Gson库。先添加对应Maven依赖,再分别通过ObjectMapper的writeValueAsString()或Gson的toJson()方法将Map转为JSON字符串,两者均几行代码即可完成转换。
-
Future.get()默认阻塞,需用超时重载或isDone()判断;抛出InterruptedException、ExecutionException、TimeoutException须分别处理;禁在UI/Servlet主线程调用;cancel()不保证资源清理,任务需自行响应中断。