-
锁消除是JVM通过逃逸分析确认对象未逃逸后自动移除无竞争同步的操作。若对象仅在方法内创建使用、不被返回、不赋值给静态字段、不传入跨线程方法,则判定为线程私有,synchronized块被JIT直接删除;典型场景包括局部new的StringBuffer、ArrayList等;但对象赋值给static字段、作为返回值、进入全局容器或逃逸分析被关闭时,锁消除失效。
-
Future.get超时后任务仍在运行,必须手动调用cancel(true)中断;重试前需确保上轮任务终止,区分TimeoutException、ExecutionException和InterruptedException处理逻辑,并合理配置线程池。
-
ATM类设计需保证线程安全:账户余额用AtomicInteger或synchronized保护;Account与ATM解耦;余额操作返回boolean;避免在getter/toString中做业务判断;withdraw需严格参数校验。
-
直接继承InheritableThreadLocal无法实现写时复制,因其childValue()仅在子线程创建时调用一次且不拦截set();需用InheritableThreadLocal透传父线程快照、ThreadLocal管理本地值,并在set()首次调用时深拷贝快照完成按需复制。
-
CopyOnWriteArraySet不适合保护“配置数组列表”,因其是Set、去重无序,底层依赖CopyOnWriteArrayList导致写操作需全量复制数组;高频读+极少写时可凑合用,但推荐按场景选CopyOnWriteArrayList或不可变List。
-
并行流会加剧GC压力,因其将任务切分为多个ForkJoinTask,各线程在本地Eden区高频创建短命中间对象,导致Eden快速填满、MinorGC频次飙升。
-
调试时发现方法返回正确值,但赋值后的变量仍为初始值(如空字符串),根本原因常是调试器在跨线程执行时无法准确反映主线索引的最新变量状态,而非赋值本身失败。
-
Instant是分布式时间戳的理想选择,因其基于纯UTC、纳秒级精度、不可变且线程安全,配合NTP同步可确保跨节点时间可比性;实际应用中应统一用Instant.now()记录事件、ISO-8601序列化、JDBC原生存储,并避免与LocalDateTime或Date混淆。
-
DuplicateFormatFlagsException与日志模板重复无关,它仅在调用String.format()等底层格式化方法且格式串中出现重复标志(如"%00d")时抛出;日志框架使用自定义解析,重复占位符不会触发该异常。
-
NavigableMap继承自SortedMap,提供有序键值对操作及导航方法,常用实现为TreeMap。1.lowerKey返回小于指定键的最大键,floorKey返回小于等于的最大键,ceilingKey返回大于等于的最小键,higherKey返回大于的最小键。示例中map.lowerKey(4)得3,floorKey(5)得5,ceilingKey(6)得7,higherKey(7)为null。2.lowerEntry、floorEntry等返回对应键的Map.Entry,可直接获取键值对,避免二次
-
应封装带受检异常的函数式接口(如IOConsumer)并在执行处用UncheckedIOException包装;CompletableFuture中需抽离DB操作并分类处理;@Async异常须显式通过CompletableFuture捕获;CountDownLatch等需手动传递异常。
-
GUI程序中禁用主线程调用join(),应通过事件通信(如write_event_value、runLater)异步更新UI;顺序任务用单线程池或CompletableFuture协调,而非阻塞等待。
-
下界通配符?superT的核心语义是容器元素类型为T或其任意父类,确保T及子类实例可安全写入,读取时仅能按Object处理,体现逆变与PECS中消费者原则。
-
类加载生命周期共七阶段:加载、验证、准备、解析、初始化、使用、卸载;其中前五阶段为核心,依次执行,加载阶段生成Class对象并存入Metaspace,验证确保字节码安全,准备为静态变量设默认值,解析将符号引用转为直接引用,初始化执行<clinit>方法赋实际值。
-
多个构造器复用初始化逻辑应抽成私有方法(如init()),避免this()调用限制;Kotlindataclass需依赖init块且次构造器必须委托主构造器;Python禁用__dict__操作,统一用_setup_*方法;Go推荐New函数封装校验与默认初始化。