-
PrintWriter默认不自动刷新缓冲区,需构造时传true或手动flush();不指定字符集易致中文乱码;非线程安全,多线程需独立实例或外层加锁。
-
Java多层继承下方法重写容易失效?看super调用链是否被意外截断Java里不是写了@Override就一定走得到子类逻辑——尤其在三层及以上继承(比如A→B→C)中,如果B没显式调用super.method(),C的重写就会被跳过。检查每层父类方法体:有没有漏掉super.xxx(),特别是模板方法模式中常见的钩子方法避免在中间类B里直接return或抛异常而不委托,这会切断向下的调用流用IDE的“FindUsages”查method()所有实现,确认调用栈是否真能触达最末子类调
-
Java堆存对象和数组等线程共享数据,栈存线程私有的局部变量、参数等;对象总在堆里因栈仅存引用,实际数据需垃圾回收与线程隔离支持。
-
应使用sa-token-spring-boot-starter启动,避免手写Filter;需配置路由拦截、Redis桥接及响应头暴露,确保token正确传递与集群支持。
-
Java继承中变量访问取决于修饰符、隐藏与引用类型:public/protected/包内默认变量可直接访问,private需getter/setter;super可访问父类变量,this优先子类同名变量;变量不具多态性,访问由编译时引用类型决定。
-
掌握Java正则表达式的高级技巧可显著提升文本处理效率。1.使用分组与捕获提取信息,如通过括号()定义组并用group()提取时间戳和用户ID;使用(?:...)可避免不必要的捕获。2.后向引用\1可确保前后匹配一致,命名组(?<name>...)提升代码可读性与维护性。3.零宽度断言如(?=...)、(?!...)、(?<=...)、(?<!...)可精确控制匹配位置而不消耗字符,适用于复杂校验。4.替换时结合appendReplacement与函数逻辑实现动态替换,如将数字替换
-
Record类是Java14+专为不可变DTO设计的语法糖,自动生成final字段、构造器及equals/hashCode/toString/getter,但要求无行为、不继承、值初始化后不变。
-
Java集合对null支持差异显著:ArrayList/LinkedList允许任意位置存null;HashMap/LinkedHashMap允许一个null键和多个null值;TreeMap/TreeSet完全禁止null;ConcurrentHashMap拒绝null键值,CopyOnWriteArrayList允许add(null)。
-
Arrays.asList()返回的是Arrays的私有静态内部类ArrayList,未重写add/remove方法,调用抛UnsupportedOperationException;基本类型数组需用IntStream转装箱;该List与原数组共享数据,非独立副本。
-
InetAddress.getLocalHost()不可靠,应遍历NetworkInterface获取真实网卡IP;getByName("www.baidu.com")抛UnknownHostException是因DNS解析失败;IPv6地址带%后缀需截断或用InetAddress对象直连;DNS缓存需合理配置TTL。
-
项目SDK与模块SDK不一致会导致编译报错或NoClassDefFoundError,因模块SDK才真正决定字节码版本、语言特性及依赖解析,两者冲突时IDE行为不可预测,且Gradle同步可能覆盖设置。
-
确认内存泄漏需观察老年代使用率“只涨不跌”、FGC频次激增且回收无效、OOM频繁复现、特定类实例持续增长;jmap加live可导出纯净堆快照;MAT中通过PathtoGCRoots查强引用链,DominatorTree定位真正内存支配者。
-
hashCode决定对象在哈希集合中的存储位置,影响查找、插入、删除的平均时间复杂度;必须与equals保持一致,否则导致哈希集合行为异常;好hashCode需满足快、散、稳三特征。
-
本文详解如何在Javalin应用中配置静态资源目录,并通过服务端重定向方式自动响应PDF请求,避免流读取失败问题,实现安全、简洁的静态文件分发。
-
JDK包含JRE,JRE包含JVM;装JDK即自带JRE和JVM,仅运行程序只需JRE;JVM依赖JRE的rt.jar等类库,显式使用-cp会忽略默认类路径,导致NoClassDefFoundError。