-
线上压测需用CountDownLatch实现齐发式并发、CyclicBarrier支持多轮脉冲爆发、Semaphore控制瞬时并发上限,并须绕开直连生产库、未标识流量、监控缺失及无熔断等风险。
-
AtomicStampedReference仅适用于单JVM多线程场景,无法用于分布式环境;其stamp值不跨进程同步,无法解决分布式ABA问题,分布式版本控制需依赖Redis、ZooKeeper等外部一致性存储。
-
Java的Period.between方法在计算LocalDate间隔时采用“逐月递增+自动截断”策略,导致相同月份内不同起始日(如1月28日vs1月31日)可能得出完全相同的Period结果,这是其设计使然而非Bug。
-
-XX:+UseStringDeduplication是JVM在G1GC下启用的字符串去重机制,仅对老年代中内容相同的String对象合并副本,需JDK≥8u20且配合-XX:+UseG1GC使用,可降内存占用15%–40%,附带轻微CPU开销。
-
Thread.yield()仅是向JVM发出的建议性让权提示,不保证暂停、不释放锁、不改变线程状态,实际效果微弱且依赖底层实现;适用于低竞争自旋等待或调试模拟,不可用于正确性保障。
-
左移运算符(<<)计算2的N次方本质是二进制位左移,1<<N等价于2^N(N为非负整数),速度快、编译期可优化,但需确保N不越界且非负。
-
使用PriorityBlockingQueue可实现线程安全的任务优先级排序,它基于堆结构并内置同步机制,支持多线程环境下安全的插入、删除和调度操作。通过让任务类实现Comparable接口或提供Comparator,即可按优先级排序,适用于生产者-消费者模型。相比手动同步非线程安全的PriorityQueue,PriorityBlockingQueue更简洁安全,避免了死锁与复杂等待通知逻辑。结合ThreadPoolExecutor可构建优先级调度线程池,但需注意任务优先级应在提交时确定,且任务对象应设
-
观察者模式是一种行为设计模式,用于处理对象间的一对多依赖关系。其核心在于当被观察者状态改变时,所有观察者都会自动收到通知并更新,从而实现组件间的松耦合。1.它适用于事件驱动系统、数据变化通知、消息队列或订阅系统等场景;2.Java中可通过自定义观察者接口和被观察者类来实现,包括注册、移除和通知观察者的方法;3.使用时需注意内存泄漏、线程安全及通知顺序等问题。
-
retransformClasses仅支持修改方法体,禁止增删字段/方法、调整继承或泛型签名,否则抛UnsupportedOperationException;Arthas封装了反编译→编译→校验→retransform全链路,SpringBoot4.0下需避开AOT预编译类与Agent拦截陷阱,并验证字节码生效、调用逻辑及Metaspace稳定性。
-
应根据场景选择List实现:ArrayList适合随机访问和尾部操作;LinkedList适合头尾增删;CopyOnWriteArrayList适合读多写少的并发场景;Vector已不推荐,synchronizedList需手动同步复合操作。
-
RandomAccessFile不支持文件空洞技术,seek后write会真实分配磁盘空间并填充零字节;多线程下载需每个线程独占实例、校验206响应、持久化offset并校验分片完整性。
-
Selector的wakeup()方法用于中断其当前阻塞等待,使线程立即返回并重新轮询;多线程协作中,当其他线程注册新事件而Selector正在阻塞时需调用以及时处理;它线程安全,多次调用不累积,仅确保至少一次唤醒。
-
上界通配符使用?extendsType形式,用于限定泛型类型为某类及其子类,适用于只读场景。例如List<?extendsNumber>可接收List<Integer>或List<Double>,允许读取为Number类型,但禁止添加除null外的元素,确保类型安全,提升代码灵活性。
-
Java调试功能内置于JDK中,无需单独安装;需正确配置JAVA_HOME和PATH,使用IDE图形化调试(基于JDWP协议),或通过jdb命令行、远程调试参数启动调试。
-
JUC不是替代老式同步机制,而是通过高级抽象解决并发场景的可扩展性、可靠性与开发效率问题:提供ReentrantLock、Condition等语义明确工具,线程安全集合,ExecutorService任务调度,以及Atomic原子类和StampedLock等无锁编程支持。