-
多态提升扩展性:新增子类无需修改调用方代码,只需实现统一接口,通过工厂或Spring注入即可;避免if-else硬编码、接口污染和散落new,保障开闭原则与可维护性。
-
OutOfMemoryError:GCoverheadlimitexceeded并非堆内存真正耗尽,而是JVM检测到最近98%时间用于GC却仅回收不足2%堆空间,判定无效运行而主动终止,本质是GC频繁低效,多由内存泄漏或对象生命周期失控导致。
-
Arrays类提供静态工具方法简化数组操作但不改变原数组结构;Arrays.asList()返回固定大小列表,需newArrayList()包装才支持增删;基本类型数组转List须先转包装类型或用Stream。
-
InterruptedException是线程被中断时抛出的检查异常,需恢复中断状态或向上抛出,不可吞掉;它表示协作式中断通知,非线程终止信号。
-
匿名内部类访问局部变量必须加final,是因为局部变量存于栈中、方法结束即销毁,而内部类对象在堆中可能长期存在;Java通过编译时复制值/引用并存为内部类私有字段来解决生命周期不一致问题,final确保副本与原始值始终一致。
-
线程池通过复用预先创建的线程,避免频繁创建销毁带来的开销,提升系统性能与稳定性。ThreadPoolExecutor是Java中实现线程池的核心类,其核心参数包括corePoolSize(核心线程数)、maximumPoolSize(最大线程数)、keepAliveTime(非核心线程空闲存活时间)、workQueue(任务队列)、threadFactory(线程工厂)和handler(拒绝策略)。这些参数共同决定了线程池的行为:当任务提交时,优先使用核心线程执行;核心线程满载后任务进入队列;队列满则创建
-
SpringBoot通过@Bean注解在配置类中声明工厂方法,可完全替代XML配置或手动工厂调用,实现接口与其实现类的解耦注入,无需额外配置类即可完成面向接口的依赖注入。
-
SocketException由网络连接问题引发,需通过捕获异常、重连机制、资源管理和日志监控等措施处理;常见原因包括连接被重置、超时、套接字关闭及网络中断,应使用try-catch块捕获具体异常类型,优先处理子类异常,并结合指数退避、心跳检测和超时设置提升程序健壮性。
-
Java中数组不支持直接调用stream()方法,需通过Arrays.stream()将其转换为流,才能使用filter、findFirst等Stream操作完成对象筛选。
-
可重入锁允许同一线程多次获取同一把锁而不阻塞,其核心是“线程绑定+计数器”机制,通过state值记录加锁次数、持有线程引用确保仅该线程可重入;用于避免嵌套调用死锁,支持公平/非公平模式,且必须配合try-finally确保unlock。
-
Java中按条件拆分集合推荐用Collectors.groupingBy()配合Lambda,支持单条件(如布尔值或语义化字符串)、多条件(record或字符串拼接)分组,可嵌套收集器取每组前N条,并需妥善处理null值。
-
不能直接newList(),因为List是接口,Java不允许实例化接口;必须使用其实现类如ArrayList,推荐写法为Listlist=newArrayList()。
-
本文详解在无网络环境下,通过--offline模式构建SpringBoot项目时,如何正确配置本地插件(如spring-boot-gradle-plugin),包括插件命名规范、buildscript依赖声明、必需的传递依赖(如spring-boot-loader-tools)及离线依赖管理最佳实践。
-
不加volatile的DCL会因指令重排序导致其他线程看到未初始化完成的实例,引发NullPointerException;volatile禁止重排序并保证可见性,是JDK5+下DCL正确性的关键。
-
虚拟线程是JVM用户态轻量级线程,通过Continuation挂起/恢复,不映射OS线程,不可join/interrupt/synchronized,适用于I/O密集型任务,禁用于CPU密集型,需用StructuredTaskScope替代传统线程池。