-
可在不破坏闭包语义前提下用函数式接口封装异常处理,须保持签名不变、不泄露实现、不改变成功路径预期;包裹器应继承原接口异常能力、避免new/this引用、通过组合式链式调用组装纯函数handler、显式隔离副作用、谨慎翻译异常、禁用阻塞操作,并与default方法协同分层扩展。
-
硬编码魔法值在分支结构中危害严重,应通过语义化封装、规则外置化、策略模式和快照日志实现可配置、可审计的规则体系,并渐进式落地。
-
Java中一维数组推荐写法是int[]arr,强调类型整体性;intarr[]为C风格易引发歧义,如inta[],b;中仅a是数组。声明不初始化则arr为null,访问length或元素会抛NullPointerException。
-
ArrayList.remove(intindex)删除非末尾元素时,内部在fastRemove()中调用一次System.arraycopy,将elementData[index+1]至末尾元素前移一位,覆盖被删位置,不缩容数组长度。
-
Netty中配置自签名证书需用SelfSignedCertificate指定域名(如"localhost")以满足SAN校验,客户端禁用默认信任管理器(测试用InsecureTrustManagerFactory),服务端正确创建SslHandler并确保其位于pipeline首位,同时注意证书与私钥分文件且私钥不加密。
-
anyOf不能用于“首选快速响应”策略,因其只认完成不认成功,易将超时异常当有效结果;返回Object需包装或用applyToEither避免ClassCastException;必须校验result和ex有效性并设独立线程池、超时与兜底。
-
轻量级锁的获取依赖CAS成功或有限自旋,失败则膨胀为重量级锁;其核心是用户态下基于CAS的无锁化竞争,适用于极短临界区,不适用于I/O或耗时操作。
-
包可见性是Java中一种恰到好处的封装手段,使成员仅对同包类可见,兼顾内聚协作与边界控制,需配合功能导向包结构和同包测试实践。
-
Stream.of适用于已知数量的零散对象,接收可变参数生成顺序流;误用会导致非空流、类型推导错误或数组未展开等问题,应据输入形态选用Stream.of、Arrays.stream或collection.stream()。
-
Java9模块系统(JPMS)不支持跨模块直接传递对象或运行时契约验证,module-info.java仅声明静态可见性契约;对象传递需通过ServiceLoader等运行时机制实现,契约验证需结合接口、注解与显式校验。
-
使用Comparator配合Arrays.sort()实现逆序排序的关键是翻转比较逻辑,如b-a或b.compareTo(a),推荐用reversed()方法确保健壮性。
-
JOL无法稳定捕捉锁升级全过程,因其仅解析Java堆内结构,而重量级锁指针在C++堆、轻量级锁地址在栈帧且易被JIT优化,偏向撤销时MarkWord可能被置零或全1;需禁用逃逸分析与JIT优化,单线程内分步新建对象并即时抓取布局,结合jstack验证重量级锁。
-
Package.getAnnotations()通常为空,因为package-info.java中的注解默认为SOURCE保留策略,编译后即丢弃,且JDK的Package类不解析package-info.class中的注解。
-
Java无法直接播放MP3,因javax.sound.sampled不支持压缩格式;须用JLayer解码为PCM后通过SourceDataLine输出,注意中文路径、缓冲区管理和资源释放。
-
Properties.load()读不到文件主因是路径错误或资源未正确加载,应使用类加载器getResourceAsStream()获取流并判空;中文乱码需用UTF-8Reader加载;SpringBoot中应优先使用@ConfigurationProperties而非手动加载。