-
DCL单例易出错主因是未用volatile导致指令重排序,使线程看到未初始化完成的对象;必须用volatile修饰instance、双重检查、锁类对象,缺一不可。
-
System.console()在IDE中返回null是因缺乏底层TTY支持,仅在系统终端运行jar时有效;readPassword()返回char[]为安全设计,需手动清零;Windows中文路径会导致编码问题;多环境部署应放弃该API,改用适配方案。
-
Proxy.getProxyClass()仅生成代理类,不检查是否已被代理;判断对象是否为代理实例应使用Proxy.isProxyClass()和Proxy.getInvocationHandler()。
-
高并发下应避免synchronized全局锁,因其导致请求串行化、吞吐量骤降,并易引发线程饥饿或死锁;优先使用AtomicInteger、ReentrantLock(带超时)、ConcurrentHashMap等并发工具。
-
CallerRunsPolicy的核心价值是作为压力调节阀,通过调用者线程同步执行任务实现反压降级;适用于不能丢任务、可容忍短时延迟、上游线程可控的场景,需配合有界队列、合理线程数及短耗时任务(≤200ms)使用。
-
使用volatile标志和中断机制可实现Java线程安全取消,通过定期检查状态或捕获InterruptedException响应取消信号,结合Future.cancel(true)统一管理任务生命周期,并在finally块中清理资源,确保无泄漏。
-
printStackTrace()可快速输出完整堆栈到System.err,适用于开发调试;需判空避免NPE;获取字符串应使用StringWriter+PrintWriter;日志中须传Throwable实例而非字符串拼接。
-
非公平锁性能更高,因其在lock()中优先执行compareAndSetState(0,1)直接抢锁,跳过AQS队列操作;而公平锁需先调用hasQueuedPredecessors()检查队列头部,引发内存屏障和缓存同步开销,导致吞吐下降。
-
关键在于匹配任务特性做轻量调度:纯计算型设CPU核数+1;含IO型按公式CPU×(1+IO等待/CPU计算)估算;用有界队列+CallerRunsPolicy反压;剥离阻塞点并强制超时;动态扩缩容适配流量。
-
Double.compare()是处理double排序的推荐方式,它天然支持NaN、正无穷和负无穷,保证排序行为一致可预测,避免了直接使用==或<等运算符导致的异常。
-
BlockingQueue是Java中实现生产者消费者模式的线程安全工具,位于java.util.concurrent包下,通过put()和take()方法实现阻塞操作,当队列满时生产者阻塞,空时消费者阻塞,无需手动同步;其常用实现有ArrayBlockingQueue(有界数组队列)、LinkedBlockingQueue(可选有界链表队列)和SynchronousQueue(不存储元素的同步队列);示例代码展示使用ArrayBlockingQueue进行生产和消费,生产者每500毫秒发送消息,消费者每
-
公共变量库升级需依托模块描述文件实现治理:严格语义化版本控制、导出粒度约束、多阶段灰度兼容、CI/CD流程绑定,使模块描述成为贯穿研运全链路的动态契约。
-
Java匿名内部类必须用new和{}定义,本质是编译生成的独立类文件,仅能继承一个类或实现一个接口,可访问外部final变量,但易致内存泄漏,Lambda仅适用于函数式接口。
-
局部类是定义在方法内部的类,用于精准隐藏变量和行为,其作用域限于该方法,可访问final或effectivelyfinal的局部变量及外部类所有成员,编译后生成独立.class文件。
-
Executors.newSingleThreadExecutor本身不会导致元空间溢出,根本原因是类加载过多且未卸载;若其执行的任务涉及动态类生成、强引用ClassLoader或未清理ThreadLocal,则可能间接引发MetaspaceOOM。