-
元空间溢出主因是动态类加载未卸载及参数设置过小,而非反射本身;需结合-XX:MetaspaceSize=256m、-XX:MaxMetaspaceSize=512m调优,并优先静态替代反射、缓存Method、改用MethodHandle或JDK代理规避CGLIB类生成。
-
线程假死源于JIT优化后循环缺失safepoint,表现为CPU高但jstack无响应、GC无法触发;需用top/jstack/ps定位异常线程,通过-XX:+PrintSafepointStatistics等参数验证,并以volatile读或Thread.onSpinWait()修复。
-
Files.isWritable()不能可靠判断系统写权限,仅检测指定路径是否存在且可写;应采用三步预检:确认目录存在可遍历、创建删除临时文件探针、检查可用磁盘空间。
-
Scanner.hasNext(Pattern)是阻塞的,因System.in底层为阻塞流,无法超时或取消等待;真正非阻塞需用NIO、Console.ready()或线程+超时封装,但推荐重构交互逻辑避免此需求。
-
系统功能包括发布、查看列表与详情及管理操作;2.采用SpringBoot、Thymeleaf、JPA与MySQL;3.定义Article实体与仓库接口;4.控制器处理请求并交互页面;5.Thymeleaf渲染前端;6.可扩展富文本、登录、分类等。
-
加-Dverbose才能看到依赖冲突,因默认裁剪重复依赖;冲突表现为同groupId:artifactId多路径不同version;生效版本由路径最短优先、声明顺序次之决定。
-
泛型运行时类型参数虽被擦除,但类结构、字段名、方法签名及注解等元数据仍保留在字节码中;ORM利用反射获取的泛型声明(如ParameterizedType)、泛型类独立Class对象、泛型边界约束及工厂注入Class<T>实现高效映射与类型安全。
-
Eclipse中直接导出为ZIP会导致导入后丢失包结构和构建路径;应使用“ExportasJAR”功能生成标准JAR文件,并确保Manifest中配置Main-Class,才能保证项目可导入、可编译、可执行。
-
Collections.checkedCollection是Java运行时类型安全包装器,通过在add、addAll等写入操作时用getClass()与指定Class精确匹配校验元素类型,防止ClassCastException,但不检查已有元素、不支持协变、不可绕过原始引用操作。
-
最常见报错是“Nosuitabledriverfound”,因未加载对应JDBC驱动JAR;执行卡住多因连接被占用;中文乱码源于URL缺编码参数;导入SQL后需Reloaddatabase刷新元数据;驱动与数据库版本须严格匹配。
-
应关注路径分隔符、换行符、文件权限等底层行为而非os.name;配置文件需分层加载并避免硬编码路径;容器中须显式设置时区;数据库连接host不可写localhost,且注意JDBCSSL配置。
-
ConcurrentHashMap迭代器是弱一致性的,它不加锁、无死锁风险,遍历时按桶顺序读取当前头节点,已扫位置的修改不可见,未扫位置的新写入可能被后续捕获,结果为近似快照叠加部分增量。
-
类是对象的模板,定义属性和方法;对象是类的实例,通过new创建并独立存储数据;构造方法初始化对象,访问修饰符控制成员可见性,实现封装。
-
hasNextBigDecimal()不适合财务校验,因其仅做基础词法识别,不检查科学计数法、小数位数、非负性、无穷值及非法字符;应先用正则预检再安全解析。
-
Integer缓存池可扩容至-128~200000,通过-XX:AutoBoxCacheMax=200000实现;Long等类型缓存不可调,需用ConcurrentHashMap显式代理;验证用JFR或-XX:+PrintClassHistogram,判等必须用equals()。