-
Java原生序列化不处理循环引用致StackOverflowError,需用XStream/FST/Kryo等支持引用的库;transient字段反序列化后为null因未初始化;serialVersionUID不一致引发InvalidClassException,应显式声明并按变更规则更新;Jackson默认不识别transient且需注解或配置支持循环引用与对象同一性。
-
扫雷核心用二维数组表示格子,元素存未翻开(0)、是雷(-1)或周围雷数(1~8);初始化全0后随机布雷并去重;首次点击才生成数字;点击0格时用BFS递归展开相邻0区域,配合八邻域偏移和边界检查。
-
JDK动态代理通过接口+反射+InvocationHandler统一实现权限校验与事务管理,要求目标类必须实现接口;invoke方法中按序执行权限检查、事务开启、业务调用、提交/回滚;支持注解驱动的条件增强。
-
VerifyError是JVM在类加载连接阶段强制校验字节码失败时抛出的致命错误,发生在ClassLoader.defineClass()阶段,因类型不匹配、栈不平衡等违反JVM规范的问题导致,属不可恢复的Error而非Exception。
-
TimeZone是Java处理时区的抽象类,需通过getTimeZone()等静态方法获取实例,提供偏移量、夏令时规则及时区ID等元数据,配合Calendar或ZonedDateTime完成时间转换;推荐使用java.time包替代。
-
FastThreadLocal通过线程专属数组与固定下标实现零哈希、零探测的直接访问,提升缓存局部性与查找速度;需搭配FastThreadLocalThread使用,staticfinal复用实例避免索引爆炸。
-
ArithmeticException是Java中不强制捕获的运行时异常,仅在int、long等整数类型除零时抛出;float/double除零返回Infinity或NaN;应前置校验分母而非依赖try-catch。
-
死锁的本质是争夺顺序不一致与持有资源后继续等待导致的闭环,典型如两线程反序申请mtx1和mtx2:A持mtx1等mtx2,B持mtx2等mtx1,满足互斥、持有并等待、不可剥夺、循环等待四条件。
-
InvocationTargetException是反射调用异常的包装器,真实异常需通过getCause()获取;多层嵌套时应循环解包,推荐使用Spring的ExceptionUtils.unwrapInvocationTargetException()。
-
File.isHidden()不检测系统级隐藏属性,Windows下检查Hidden标志,macOS/Linux仅判断文件名是否以.开头;应优先用Files.getAttribute获取dos:hidden(Windows),macOS需调用xattr或stat命令,跨平台需分层降级处理。
-
Collections.synchronizedList仅保证单方法线程安全,不解决复合操作、迭代并发及状态依赖问题;需手动同步迭代、避免底层暴露,锁粒度粗影响读性能,应依读写比例与一致性需求选替代方案。
-
for-each循环本质是编译器对Iterator的语法糖,要求对象实现Iterable接口并提供每次返回新迭代器的iterator()方法;其背后执行Iterator的hasNext()、next()三步操作,支持fail-fast但不支持倒退或修改结构。
-
要计算两个时间点的秒数差,必须使用Instant等时间点类型而非Duration;推荐用Duration.between(start,end).toSeconds()获取四舍五入后的整秒数,注意LocalDateTime直接相减存在时区陷阱。
-
public全开放;protected同包+不同包子类可访问但外部不可点调;default仅同包可见且不继承;private仅本类可见。模块化后default受模块边界限制。
-
线程池过大导致性能下降的主因是上下文切换开销激增。当线程数远超CPU核心数,频繁切换(1–5μs/次)吞噬大量CPU时间,吞吐不升反降;需据任务类型(CPU/I/O密集)合理设定线程数,避免盲目扩容。