-
网关热部署错误码关键在于异常结构化与动态生效:ErrorCode需为枚举含code/httpStatus/messageTemplate,BusinessException构造时注入上下文并保留cause,ErrorWebExceptionHandler按类型+错误码双路由响应,通过SPI加载独立异常模块实现热更新。
-
do-while循环适合“先执行、再判断”的交互场景,如命令行工具中执行操作后询问是否继续;它保证至少执行一次,需用nextLine()处理输入残留,并校验空输入与大小写,可封装为askContinue方法复用。
-
Java中GZIPOutputStream是JDK自带的gzip压缩方案,需调用close()确保CRC和长度信息写入,避免解压异常;小数据解压时read()返回0属正常,应循环至-1;多文件需先tar再gzip。
-
最直接做法是用replaceAll("\D","")但易误删,应使用replaceAll("1","")确保只保留ASCII数字;需提取多个独立数字时应用Pattern+Matcher配合"-?\d+\.?\d*"等正则分情况匹配。0-9↩
-
基于掩码的IP地址解析核心是将IP和掩码转为四段整数数组,逐段按位与运算得出网络地址;需校验每段0–255合法性,支持点分十进制与CIDR两种输入格式,同网段判定即比较网络地址数组是否完全一致。
-
Java整数字面量默认为int类型,超2147483647必须加L;浮点字面量默认double,float需加f;后缀影响泛型推断、方法重载和编译期检查。
-
String.length()返回char个数,String.codePointCount()返回Unicode码点数;因UTF-16中代理对(如emoji、部分汉字)占2个char,故二者结果可能不同。
-
标记清除算法导致老年代内存碎片的核心原因是只回收垃圾对象而不移动存活对象,使空闲空间离散分布;老年代对象长期存活、数量多且体积大,无法采用复制算法,只能就地标记清除,最终因缺乏连续空间而频繁触发FullGC甚至OOM。
-
Java数组是引用类型,声明需明确元素类型和维数,推荐写法为int[]array;初始化分静态(如int[]arr={1,2,3})和动态(如int[]arr=newint[5])两种;访问越界抛ArrayIndexOutOfBoundsException。
-
groupingBy嵌套summarizingInt不能直接两层因后者返回IntSummaryStatistics而非Collector;正确做法是外层groupingBy分组、内层summarizingInt统计,结果为Map<String,IntSummaryStatistics>。
-
new出来的对象不一定在堆上,因逃逸分析可判定其是否逃逸:未逃逸时JVM可栈上分配或标量替换;方法逃逸或线程逃逸则必须堆分配。
-
必须通过反射获取theUnsafe字段并setAccessible(true),JDK9+还需--add-opens参数;allocateMemory返回的地址需手动管理生命周期,重复free或越界访问将导致JVM崩溃。
-
Java9起接口可用private方法抽取多个default方法共用逻辑,既复用代码又不暴露给实现类;它专用于接口内部封装校验、日志、格式化等重复行为,仅限本接口内default或static方法调用,不可被实现类访问或反射调用。
-
推荐组合优于继承,因其更契合业务可变性与可控性:组合明确区分“拥有什么功能”和“是什么类型”,避免继承的脆弱基类、单继承限制、语义失真及封装泄露问题,支持运行时切换、易测试与高内聚。
-
局部类通过编译器生成私有字段并构造时传入值或引用,将effectivelyfinal变量“搬家”到堆上与实例绑定共存亡;修改其指向对象内部状态可绕过final限制。