-
多态通过策略模式+工厂将类型选择上移到对象创建处,调用方只面对统一接口;枚举+抽象方法适合固定分支场景;模板方法固化共性流程;但参数校验等非类型分支应保留if。
-
判断字符串为空或空白应先判null再trim().isEmpty(),或用StringUtils.isBlank()、JDK11+的isBlank();substringendIndex不包含且需满足索引范围;replace处理字面量,replaceAll处理正则;循环拼接必须用StringBuilder。
-
本文详解Android中因Handler自定义消息ID(如11、22)与系统保留ID冲突,导致handleMessage()无法被调用的根本原因,并提供基于Handler.post(Runnable)的安全替代方案,附完整可落地的代码重构示例。
-
DFA比正则更适合敏感词脱敏因其一次构建、多次复用,匹配为纯状态跳转,时间复杂度O(n),不随词库规模恶化;而正则在词量大时编译开销高、匹配需回溯,易漏匹配或性能骤降。
-
使用Guava的Lists.partition()方法可快速将List按大小拆分,如每3个元素一组;Java8Stream可通过索引分组实现相同功能,无需额外依赖;手动循环则适合简单场景,代码直观易懂。
-
JavaAgent的premain不执行主因是JVM未正确加载代理,需通过-javaagent指定jar路径且MANIFEST.MF中声明Premain-Class;-javaagent必须置于java命令最前,MANIFEST文件不能含BOM或多余空行。
-
迁移至JakartaEE不仅是包名从javax.到jakarta.的变更,更是技术栈全面升级,需重构代码、更新依赖、适配新应用服务器,并借助EclipseTransformer或OpenRewrite等工具实现自动化转换,同时确保第三方库兼容性与测试全覆盖,以应对API变化与配置调整,最终实现向云原生、社区驱动的现代化企业级Java平台演进。
-
Java无法强制终止线程,唯一安全方式是协作式中断:线程需主动检查interrupt()标志并优雅退出,配合isInterrupted()、正确处理InterruptedException及资源清理。
-
ConcurrentLinkedDeque是基于CAS无锁算法实现的线程安全双端队列,适用于高并发低争用场景;支持两端高效增删、弱一致性迭代器、非实时size(),不允null元素,适合工作窃取、日志缓冲等最终一致性场景。
-
finally总在try或catch执行完后、方法返回前执行,无论是否异常或return;若finally含return则覆盖原返回值;System.exit()等极少数情况不执行。
-
答案:Java中解析XML需通过try-catch处理SAXParseException、ParserConfigurationException、SAXException和IOException等异常,结合DOM、SAX或StAX方式,捕获后可定位错误位置并提升系统健壮性。
-
MessageDigest不能加密,只生成不可逆的固定长度摘要;SHA-256是推荐算法,MD5和SHA-1已不安全;需注意线程不安全、编码一致性和digest()自动重置状态等关键细节。
-
积分系统核心是精度、性能与一致性,应使用long存储最小单位积分(如1积分=100小积分),禁用float/double;数据库用BIGINT;网关层统一转换前端浮点输入;单账户变更可用AtomicLong,但“查-判-扣”需CAS或加锁保证原子性。
-
异常是程序运行中的不正常事件,Java通过try-catch-finally和throw、throws机制处理,将异常封装为Throwable的实例;Exception表示可处理的异常,Error表示系统级错误;使用try捕获、catch处理、finally释放资源;受检异常需显式处理,非受检异常为运行时异常;可自定义异常类继承Exception或RuntimeException,并用throw抛出,提升程序健壮性。
-
最外层异常是未被内层catch捕获、最终冒泡至调用链起点的异常;需避免静默吞错、显式重抛、顶层标记上下文、利用cause/name增强溯源,并区分真假嵌套。