-
Java中用Inflater解压需先剥离zlib/gzip头部,再调用setInput装填数据,循环inflate直至finished()为true,并务必调用end()释放资源,否则易致内存泄漏。
-
Java命令报错是因为插件不提供JDK,需手动配置JDK路径到PATH和JAVA_HOME,并确保VSCode正确加载环境变量;项目需有src、pom.xml或build.gradle等标识文件,且settings.json中java.home须指向JDK根目录并重启生效。
-
CAS能力由Unsafe类提供,但开发应使用java.util.concurrent.atomic包中的AtomicInteger等封装类;它们通过compareAndSet接口屏蔽底层细节,并已处理自旋、内存屏障与重试逻辑。
-
用String.lastIndexOf("/")找最后一个斜杠位置再substring截取可获取文件名,但需兼容Windows反斜杠、处理路径结尾斜杠或空字符串等边界情况。
-
受检异常是编译期契约机制,非控制流工具;应通过分层异常处理、语义化包装(如将SQLException转为DataAccessException)和统一异常处理器(如@ControllerAdvice)实现精准响应,避免在业务逻辑中用多层catch做分支。
-
核心思路是将全局强一致校验收缩至局部数据块内,通过轻量级JOIN链路实现闭环计算:以局部驱动表替代全局判定、用物化中间结果代替实时强查、以嵌套块JOIN替代逐行校验、用索引加速的INLJ替代锁表扫描。
-
MyBatis中Mapper接口与XML绑定需满足三严格:文件名与接口名完全相同、XML置于resources下同包路径、namespace必须为接口全限定名;方法名与SQL标签id须字面一致;接口不可有实现类或组件注解。
-
flatMap本身不执行哈希计算,而是将嵌套/分片数据扁平化为原子单元流(如记录、键值对),供后续哈希操作高效并发处理;它支撑动态哈希的三大环节是:拆解分片为记录流、单记录生成多哈希键、安全过滤空/无效数据保障流连续性。
-
应在参数逻辑非法时抛IllegalArgumentException,如负数ID、null非空参数等;需带具体提示信息,避免敏感数据;Spring@Valid、Lombok@NonNull可简化校验;不应捕获该异常作流程控制。
-
ForkJoinPool适合可递归分解的CPU密集型任务,如归并排序、树遍历、分治计算和并行聚合;不适合阻塞I/O、强顺序依赖、频繁共享写入或超短耗时任务。
-
Java强制类型转换需谨慎:基本类型转换可能截断或丢失精度,引用类型向下转型须用instanceof校验以防ClassCastException,泛型因类型擦除无法安全转换参数化类型。
-
StringBuffer通过synchronized方法确保多线程下字符串拼接的线程安全,如append等操作互斥执行,避免竞态条件;示例中两线程分别追加A和B,最终长度正确为2000;建议多线程共享场景用StringBuffer,单线程用StringBuilder提升性能。
-
List.of()和Map.of()创建的集合不能add/remove,因为它们返回JVM内置不可变实现类(如ListN、MapN),所有修改操作均直接抛UnsupportedOperationException;不支持null、有参数数量限制(List.of最多10个)、Map.of重复key在Java14+编译期报错;适用于配置项、映射表等只读场景,但不防元素内部可变。
-
ForeignLinkerAPI是Java16引入的孵化特性,位于java.lang.foreign包,需显式启用预览支持;它提供静态类型、纯Java方式访问本地代码,须配合SymbolLookup和MemoryLayout精确声明函数签名与内存布局,并由Arena显式管理内存生命周期。
-
isEmpty()更快但差异可忽略,JVM优化后性能基本无差别;语义上isEmpty()更清晰安全,新代码应优先使用。