-
G1通过将堆划分为2048个可动态角色的Region实现精细化回收,停顿时间目标为软约束并依赖历史数据预测,MixedGC基于各Region存活率而非老年代整体使用率触发,配置不当易引发FullGC或性能下降。
-
JavaScript的%是求余而非取模,导致负数索引错误;应使用((i%n)+n)%n映射到[0,n)区间,注意防御n=0和浮点索引。
-
单纯用System.currentTimeMillis()配合Random无法绝对保证唯一性,因毫秒级时间戳在快速调用或时钟回拨时易重复,需叠加随机数和进程/线程标识;推荐组合时间戳+6位随机数+PID,或直接使用Files.createTempFile、UUID等更可靠方案。
-
Gradle项目需显式配置Java17:Gradle7.0+用java{version=JavaVersion.VERSION_17},旧版用sourceCompatibility='17'与targetCompatibility='17',并确认org.gradle.java.home指向正确JDK路径。
-
<p>Java中生成[min,max]闭区间随机整数最推荐用Random.nextInt(max-min+1)+min或ThreadLocalRandom.current().nextInt(min,max+1),避免重复创建Random实例。</p>
-
反射的核心价值是“运行时解耦”,通过字符串动态决定行为,支撑Spring、MyBatis等框架;Class获取方式(Class.forName、obj.getClass、类.class)在类加载时机、异常和适用场景上差异显著;调用私有成员需setAccessible(true),但受SecurityManager限制;泛型已擦除,final字段修改可能无效;性能损耗大,必须缓存Method。
-
clear()不一定快,因其对大ArrayList会逐个置null以助GC,引发暂停抖动;应据场景选newArrayList()、trimToSize()、ThreadLocal或ArrayDeque等替代方案。
-
双重检查锁通过两次判空和volatile保证线程安全与性能,避免多线程下重复创建实例,同时实现懒加载。
-
不能直接用substring()提取路径参数,因为路径参数位置不固定,需用indexOf()动态定位分隔符并处理边界(如-1检查)、多段路径层级、查询参数/锚点剥离及大小写兼容性等问题。
-
将long类型序列化为字符串是最稳妥的解法,因JavaScript数字精度限制(±9007199254740991),而Javalong最大值远超此范围,直接传数字会导致ID被四舍五入;推荐全局配置Jackson将Long转字符串,或字段级用@JsonSerialize或@JsonFormat注解。
-
Java7起switch支持String但不处理null,必须提前判空;推荐在switch前用if处理null,或用Objects.requireNonNullElse提供默认值,避免casenull、equals替代及catchNPE等错误做法。
-
Exception和Error本质不同:Exception是程序可预判、可干预的异常,分检查型(如IOException)和非检查型(如NullPointerException);Error是JVM严重故障(如OutOfMemoryError),不可恢复,不应捕获处理。
-
策略模式通过组合实现运行时算法切换,适用于频繁更换算法场景;模板方法通过继承固定流程结构,适用于流程稳定、步骤局部可变的场景。
-
InternalError是JVM内部严重故障信号,不可被捕获处理;其出现表明JVM状态已不可信,应通过诊断日志、版本升级、环境排查定位根源,而非业务代码干预。
-
答案:Java中Date表示时间点,Calendar用于日期操作,两者可相互转换并借助SimpleDateFormat格式化,但建议新项目使用java.time包。