设计模式实战:用 Java 优雅实现适配器模式解决接口不兼容 在日常的系统开发或重构中,我们经常会遇到这样的尴尬场景:系统需要引入一个新的第三方库,或者需要兼容一个老旧的遗留系统。但是,这些外部或老旧系统的代码往往与我们当前系统内部的标准接口不一致。甚至在很多历史遗留项目中,压根就没有定义接口规范,业务逻辑被死死地硬编码在具体的类中。 如果我们直接修改现有的核 2026-06-07 后端探秘 14 野猪凌梦
JDK 9+ 观察者模式最佳实践:告别废弃 API,拥抱 PropertyChangeSupport 在 Java 开发中,观察者模式(Observer Pattern)是我们处理对象状态变化与事件解耦的常用利器。很多老旧的教程中仍然在使用 java.util.Observer 和 java.util.Observable 来实现该模式,但如果你使用的是 JDK 9 或更高版本,你会发现这两个类已经 2026-06-06 后端探秘 4 野猪凌梦
深入理解单例模式:DCL 双重检查锁为什么必须加 volatile? 在 Java 开发中,单例模式是我们最常用的设计模式之一。为了实现延迟加载并保证线程安全,双重检查锁(Double-Checked Locking,简称 DCL)是一种非常经典的写法。 然而,很多人在手写 DCL 单例时,往往只记得加上 synchronized 同步锁,却忽略了极其关键的 vola 2026-06-05 后端探秘 4 野猪凌梦
告别繁琐配置:基于 Auth0 的超轻量级 Java JWT 工具类实现 在日常的 Java Web 开发中,JWT(JSON Web Token)已经成为了实现无状态认证的标配。提到 Java 的 JWT 库,很多人第一时间会想到 jjwt。不可否认 jjwt 功能强大,但对于一些简单的项目或是微服务节点,繁琐的 Builder 和复杂的配置往往显得有些“杀鸡用牛刀”。 2026-05-30 后端探秘 2 野猪凌梦
LeetCode 283. 移动零:双指针的巧妙运用 在处理数组的原地操作(In-place)问题时,“双指针”技巧是我们必须掌握的核心武器。今天我们通过一道非常经典的 LeetCode 简单题——移动零,来深入理解快慢指针的实战应用。 📝 题目描述 题目:给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 2026-05-26 算法寻踪 4 野猪凌梦
LeetCode 438. 找到字符串中所有字母异位词:我的解题复盘与实践 在成功解决了“字母异位词分组”之后,我趁热打铁,继续挑战了相关的进阶题目——LeetCode 438. 找到字符串中所有字母异位词。 这篇博客主要记录我基于上一题核心思路的延伸,以及我的原始解法代码。 📝 题目描述 题目:给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这 2026-05-26 算法寻踪 5 野猪凌梦
LeetCode 49. 字母异位词分组:巧用哈希表与排序算法 在日常的业务开发和算法刷题中,字符串处理是一个非常经典的命题。今天和大家分享一道 LeetCode 的中等难度高频题——字母异位词分组。这道题完美契合了“找规律 + 巧用数据结构”的解题思路。 📝 题目描述 题目:给定一个字符串数组 strs,请你将 字母异位词 组合在一起。可以按任意顺序返回结果 2026-05-26 算法寻踪 5 野猪凌梦
LeetCode 3:无重复字符的最长子串(滑动窗口解法) 记录一下刷题日常。这道题是非常经典的滑动窗口问题,主要利用双指针维护一个不包含重复字符的“窗口”,配合 HashSet 进行去重。 💡解题思路 定义双指针与集合: 定义 left 和 right 两个指针,初始都指向字符串的开头。再定义一个 HashSet,用来记录当前窗口内出现了哪些字符。 窗口 2026-05-15 算法寻踪 10 野猪凌梦