-
答案:该待办事项系统基于Java实现,包含任务添加、查看、标记完成、删除及文件持久化功能。通过Task类封装任务属性,TodoManager管理任务列表并处理增删改查与数据读写,Main类提供命令行交互界面,使用ObjectInputStream/ObjectOutputStream实现对象序列化存储,程序启动时自动加载历史数据,支持跨会话保存任务状态,适合初学者掌握面向对象编程与基础IO操作。
-
可通过FileStore获取磁盘总空间和可用空间并手动计算百分比,需用getUsableSpace()/getTotalSpace()、避免除零、注意文件系统保留空间及权限影响。
-
Map.merge(word,1,Integer::sum)是词频统计的正确用法,它原子性地实现“有则叠、无则建”,避免NPE和并发丢失;勿用get+put组合或错误lambda,慎混用compute。
-
Java中“常量”实为publicstaticfinal字段,需同时满足public、static、final;final仅保证引用不可变,不保证对象内容不可变;多值常量优先用enum。
-
<p>Java注释不会被编译进class文件;//和//在编译时被javac完全丢弃,仅Javadoc注释(/*/)供javadoc工具提取生成API文档,而注解是否进入字节码取决于@Retention策略。</p>
-
<p>-Xlog:gc是JDK9+替代-XX:+PrintGCDetails的标准做法,支持可控、可过滤、可重定向的GC日志,需显式指定输出路径与时间精度标签,生产环境推荐配置为-Xlog:gc:file=/data/logs/gc.log:time,uptime,level,tags:filecount=32,filesize=64m。</p>
-
size()方法返回集合当前元素个数,类型为int;它不表示容量或内存大小,时间复杂度O(1),并发集合弱一致,数组无该方法而用length字段。
-
答案是掌握Java循环结构需理解for、while和do-while的执行逻辑,for适用于已知次数的循环,其初始化、条件判断和更新操作集中,结构清晰。
-
AQS共享模式中state语义因同步器而异:Semaphore的state表示剩余许可数(越大越空闲),CountDownLatch的state表示待完成任务数(越小越接近释放线程),该差异决定tryAcquireShared返回逻辑及阻塞/放行时机。
-
CopyOnWriteArrayList是读多写少场景下的线程安全列表,通过写时复制实现高效读取,适用于弱一致性、低频写入的并发环境。
-
答案:用Java实现任务管理工具需设计Task类和TaskManager类,通过Scanner接收用户输入,实现添加、查看、标记完成等功能,核心是类设计与集合操作。
-
subList()是Java中List内存分页最轻量的方式,但仅适用于数据已全量加载的场景;海量数据必须数据库层分页,避免OOM;需注意索引边界、并发修改异常及视图特性。
-
CompletableFuture解决了传统Future无法链式处理、组合任务、非阻塞回调、异常统一处理等硬伤,支持thenApply/thenCompose/anyOf/allOf等编排能力,并提供handle/whenComplete/exceptionally等语义明确的回调机制。
-
线程间通信的核心是协调执行顺序和共享数据,主要通过共享内存与同步机制实现。常用方式包括:使用wait()、notify()在synchronized中实现基础通信,适用于生产者-消费者模型;ReentrantLock配合Condition提供更精准的等待唤醒控制;BlockingQueue封装了线程安全与阻塞操作,简化生产者-消费者场景开发;此外还可选用CountDownLatch、CyclicBarrier等工具满足特定需求。选择依据为:简单场景用wait/notify,复杂控制用ReentrantLo
-
常见原因是用户输入非数字内容(如“95分”或直接回车)而程序用nextInt()强行读取,导致InputMismatchException;应改用nextLine()读整行并用Integer.parseInt()转换,配合try-catch处理,并注意消费换行符。