-
Collectors是Stream的终端收集器,用于将流结果规整装入指定容器;必须配合collect()使用,提供toList、groupingBy、joining、toMap等模板,需注意key冲突处理、下游收集器嵌套规则及返回集合的可变性与线程安全性。
-
答案:Java枚举可通过定义抽象方法使各常量实现不同行为,如Operation枚举中ADD、SUBTRACT等分别实现apply方法,调用时直接通过常量执行对应逻辑,避免条件判断,提升可读性、扩展性和类型安全性,适用于状态机、策略模式等场景。
-
CopyOnWriteArrayList适合读多写少场景,通过写时复制实现线程安全,读无锁但写开销大、内存占用高,不支持迭代中删除,仅提供最终一致性。
-
遍历集合时须用迭代器remove()或removeIf()安全删除,禁用collection.remove();并发场景需选CopyOnWriteArrayList或加锁;for-each或正序for循环中直接remove会引发ConcurrentModificationException或漏删。
-
Java高效拼接多个集合的关键是预估容量、批量操作(addAll而非逐个add)、按需选型(ArrayList去重用HashSet/TreeSet等)。
-
String.matches()适合轻量邮箱校验但性能差,推荐使用预编译的Pattern缓存提升性能,工程中应拒绝明显非法格式而非追求RFC5322全量兼容,需额外处理null、空格、长度等边界情况。
-
线程池拒绝策略必须选用CallerRunsPolicy或自定义策略,配合有界队列(如ArrayBlockingQueue)和显式构造的ThreadPoolExecutor;禁用Executors工厂方法;需监控活跃线程数、队列积压量及拒绝次数;多业务应拆分独立线程池实现风险隔离。
-
直接删除config目录比点击「RestoreDefaults」更彻底,因其清除编译器配置、Maven/Gradle路径、SDK绑定等关键设置,而按钮仅重置部分UI偏好。
-
包用于组织和命名类以避免冲突,类路径则告诉JVM从何处加载字节码;二者分别负责逻辑命名与物理定位,紧密配合确保Java程序正确编译与运行。
-
Java应用在Docker中启动慢、OOMKilled主因是JVM未适配容器内存限制;需启用-XX:+UseContainerSupport(8u131+默认开)、显式设-Xmx/-Xms为容器内存的50%~75%,并选用eclipse-temurin等轻量镜像、多阶段构建、正确配置HEALTHCHECK与actuator端点。
-
Java异常体系以Throwable为根,分为Error(不捕获)和Exception;Exception又分RuntimeException(非受检,如NullPointerException)和受检异常(如IOException,必须声明或捕获)。
-
Java多模块Maven项目依赖管理核心是父POM通过<dependencyManagement>统一声明版本,子模块仅写groupId和artifactId继承;模块间引用省略version,依赖关系需避免循环,构建顺序由模块依赖图决定而非<modules>顺序。
-
Collections是JDK官方维护的静态工具类,方法经充分测试、线程安全(仅限不可变/同步包装器)、性能优化;手写易忽略边界,而Collections已内置防御逻辑。
-
Java注解是继承Annotation接口的元数据,需用@Retention(RUNTIME)才能运行时反射获取;@Target限制使用位置;元注解控制行为,@Inherited仅对类继承生效;注解本身无逻辑,依赖外部机制(如反射、APT)实现功能。
-
Java线程池有4种内置拒绝策略:1.AbortPolicy抛异常,适用于支付等关键业务;2.CallerRunsPolicy由调用线程执行,实现降速,适合非实时任务;3.DiscardPolicy静默丢弃,用于可丢失任务;4.DiscardOldestPolicy丢弃最老任务,适用于新数据价值更高的场景。