-
Thread.setPriority()仅提供跨平台不一致的调度建议,不保证OS级权重,Linux/macOS基本无效,Windows略有效;应改用线程池、信号量等可控机制。
-
应避免Optional在高频路径、参数/字段/私有方法中滥用及三层以上嵌套;需用JVM工具定位分配热点,静态扫描嵌套深度,重构反模式调用,并通过Arthas验证优化效果。
-
对象必须8字节对齐,是因为64位CPU以8字节为单位读取数据,未对齐会导致跨缓存行访问,降低性能甚至引发硬件异常;同时保障long、double、volatile字段的原子性及指针压缩(CompressedOops)正确工作。
-
局部变量必须显式初始化,因Java不设默认值,编译器直接报错“variablemightnothavebeeninitialized”;作用域以最近的右大括号为准。
-
模板方法模式通过抽象类定义算法骨架,将可变步骤声明为抽象方法由子类实现,封装固定流程于final模板方法中,并提供可选钩子方法增强灵活性。
-
MetaspaceOOM前必先频繁扩容并触发FullGC,关键看GC日志中Metaspace使用量回落极少(如10240K→10240K)且Classesunloaded长期为0,结合-XX:+PrintClassLoaderStatistics确认类加载器与类数量持续增长,表明动态代理或类加载器泄漏导致卸载失效。
-
堆与非堆内存占用比例需基于MemoryUsage的used/comitted计算:堆使用率=heap.used/heap.committed,非堆使用率≈(metaspace+codeCache+compressedClassSpace).used之和/(对应).committed之和,直接内存需单独通过BufferPoolMXBean获取。
-
Java字节码增强不能直接为已有对象添加属性,只能在类级别新增字段,使新创建对象拥有该字段;因对象内存布局由Class结构在加载时固定,运行时无法扩展单个对象内存块。
-
Files.lines()抛IOException是因为其Stream懒加载,异常在终端操作时才暴露;应优先用Files.readAllLines()立即报错;注意路径、BOM、空行分割、中文乱码及BufferedReader优于Scanner。
-
Arrays类提供静态方法高效处理数组,涵盖排序(sort)、查找(binarySearch)、填充(fill)、复制(copyOf)、比较(equals/deepEquals)及转字符串(toString/deepToString),并支持通过stream()集成StreamAPI,实现函数式编程,提升代码简洁性与性能。
-
日志中动态年龄判定失效源于岗位属性与法定身份映射失准,表现为身份突变无审批、多源冲突未告警、时间点错位三类痕迹,须通过参数化阈值、签名验证和快照固化实现可审计治理。
-
未正确配置JAVA_HOME环境变量是新手常见问题,导致Maven、Tomcat等工具无法运行,JAVA_HOME应指向JDK安装目录如C:\ProgramFiles\Java\jdk-17。
-
Java9模块系统(JPMS)不支持跨模块直接传递对象或运行时契约验证,module-info.java仅声明静态可见性契约;对象传递需通过ServiceLoader等运行时机制实现,契约验证需结合接口、注解与显式校验。
-
多态通过将行为分发交给子类实现,消除冗长的条件判断。定义统一接口(如Shape、PaymentStrategy),各具体类实现对应逻辑,调用方依赖抽象而非具体类型,新增功能无需修改原有代码,符合开闭原则。结合策略模式可解耦行为选择,工厂模式则进一步封装对象创建,使主流程仅依赖抽象,提升可维护性、扩展性和测试便利性,实现“可插拔”的设计。
-
类加载生命周期共七阶段:加载、验证、准备、解析、初始化、使用、卸载;其中前五阶段为核心,依次执行,加载阶段生成Class对象并存入Metaspace,验证确保字节码安全,准备为静态变量设默认值,解析将符号引用转为直接引用,初始化执行<clinit>方法赋实际值。