-
重写clone()仍为浅拷贝,因Object.clone()仅复制字段值,对引用类型不递归拷贝;需手动深拷贝可变引用字段,否则修改副本会影响原对象。
-
volatile通过强制每次读取从主内存加载、每次写入立即刷回并使其他缓存失效,解决“修改不可见”问题;但它不保证复合操作原子性,也不能替代synchronized处理多步逻辑或状态协同。
-
字符串转数字前必须先校验合法性,避免直接解析抛异常;推荐用正则粗筛或ApacheCommonsNumberUtils等成熟工具,并注意各语言特性差异。
-
getDeclaredConstructor()找不到私有构造函数最常见的原因是参数类型不匹配(如int.class与Integer.class混淆)或目标构造器不在当前类声明中;必须用setAccessible(true)才能调用,且需注意Java9+模块封装和Android兼容性问题。
-
CompressedClassSpace是JVM中专用于存储压缩Klass指针的固定大小内存区域(默认1G),与Metaspace分离;其OOM表明该区域耗尽,常见于动态代理频繁、类加载器泄漏场景。
-
浮点数比较必须用带精度的断言,裸写==几乎总是错的,因IEEE754二进制表示存在固有精度损失(如0.1+0.2≠0.3),且编译器优化、平台差异等会放大偏差;iOS应使用XCTAssertEqualWithAccuracy,Pytest用pytest.approx,JUnit需借助AssertJ等第三方库;误差值须为正、匹配数值量级,避免整数隐式转换、单位混淆或未mock随机源。
-
groupingBy嵌套summarizingInt不能直接两层因后者返回IntSummaryStatistics而非Collector;正确做法是外层groupingBy分组、内层summarizingInt统计,结果为Map<String,IntSummaryStatistics>。
-
new出来的对象不一定在堆上,因逃逸分析可判定其是否逃逸:未逃逸时JVM可栈上分配或标量替换;方法逃逸或线程逃逸则必须堆分配。
-
必须通过反射获取theUnsafe字段并setAccessible(true),JDK9+还需--add-opens参数;allocateMemory返回的地址需手动管理生命周期,重复free或越界访问将导致JVM崩溃。
-
Java9起接口可用private方法抽取多个default方法共用逻辑,既复用代码又不暴露给实现类;它专用于接口内部封装校验、日志、格式化等重复行为,仅限本接口内default或static方法调用,不可被实现类访问或反射调用。
-
推荐组合优于继承,因其更契合业务可变性与可控性:组合明确区分“拥有什么功能”和“是什么类型”,避免继承的脆弱基类、单继承限制、语义失真及封装泄露问题,支持运行时切换、易测试与高内聚。
-
Collections.reverse()时间复杂度为O(n),适用于大多数列表反转场景,但不支持不可修改列表,需先创建副本;处理大型列表时性能线性增长,可考虑优化策略。
-
SpringBoot接口版本控制的核心在于确保API在演进过程中支持不同版本的客户端,避免旧系统崩溃。1.URI路径版本控制通过在URL中嵌入版本号(如/api/v1/users),实现简单且对客户端友好,但可能导致路由配置膨胀;2.HTTPHeader版本控制利用自定义请求头(如X-API-Version)传递版本信息,保持URL简洁但需要客户端额外设置请求头;3.内容协商版本控制通过Accept头指定版本(如application/vnd.myapi.v1+json),符合HTTP规范但实现复杂;4.
-
Future是异步结果占位符,不执行任务;get()会阻塞且需超时控制,异常包括ExecutionException、CancellationException、InterruptedException;isDone()/isCancelled()仅返回瞬时状态;无回调能力,推荐用CompletableFuture替代。
-
BufferedReader是Java中通过内部缓冲区提升字符流读取性能的包装类,需包装Reader实例(如InputStreamReader+FileInputStream),推荐显式指定UTF-8编码,优先使用try-with-resources和readLine()按行读取,避免混用读取方法及默认编码导致乱码。