改写结果处理与兜底机制
上一篇讲完了问题改写服务的完整实现,这一篇我们来看改写完成后,系统如何处理改写结果,以及如何应对改写失败的情况。
改写结果的处理
问题改写完成后,prepare 方法会拿到一个 RagRewriteResult 对象(可能为 null)。接下来要做的第一件事就是从这个结果里提取出两个关键信息:
- 改写后的问题 - 用于后续的检索和路由
- 子问题列表 - 如果问题被拆分了,需要分别检索每个子问题
// 如果改写结果为空,则退回原问题;子问题同理,至少保证有一个检索问题可用。
String rewriteQuestion = rewriteResult == null ? safeText(question) : firstNonBlank(rewriteResult.getRewrittenQuestion(), safeText(question));
List<String> rewriteSubQuestions = rewriteResult == null || rewriteResult.getSubQuestions() == null || rewriteResult.getSubQuestions().isEmpty()
? List.of(rewriteQuestion)
: rewriteResult.getSubQuestions();
这段代码看起来有点长,但逻辑很清晰,我们分开来看。
rewriteQuestion 的提取逻辑
String rewriteQuestion = rewriteResult == null
? safeText(question)
: firstNonBlank(rewriteResult.getRewrittenQuestion(), safeText(question));
这行代码用了一个三元表达式,分两种情况:
情况一:改写结果为 null
如果 rewriteResult == null,说明改写服务调用失败或返回了空结果,这时候直接用 safeText(question) 作为改写问题。
情况二:改写结果不为 null
如果改写结果存在,就调用 firstNonBlank(rewriteResult.getRewrittenQuestion(), safeText(question)),这个方法会:
- 先尝试取
rewriteResult.getRewrittenQuestion() - 如果这个值为空,就退回到
safeText(question)
safeText 和 firstNonBlank 工具方法
这两个工具方法在代码里经常出现,它们的作用是保证字符串不为 null:
/**
* 安全地获取文本,null 转空字符串。
*/
private String safeText(String text) {
return StrUtil.blankToDefault(text, "");
}
/**
* 返回第一个非空文本。
*/
private String firstNonBlank(String... values) {
for (String value : values) {
if (StrUtil.isNotBlank(value)) {
return value.trim();
}
}
return "";
}
safeText 就是把 null 转成空字符串,firstNonBlank 则是从多个候选值里找第一个非空的。
为什么要这么多层兜底?
改写服务可能会失败(模型调用失败、解析失败等),即使成功了,模型返回的 rewrittenQuestion 字段也可能为空。系统通过多层兜底,保证无论发生什么情况,都至少有一个可用的问题文本,不会让后续流程因为空值而中断。
rewriteSubQuestions 的提取逻辑
List<String> rewriteSubQuestions = rewriteResult == null || rewriteResult.getSubQuestions() == null || rewriteResult.getSubQuestions().isEmpty()
? List.of(rewriteQuestion)
: rewriteResult.getSubQuestions();
这行代码也是一个三元表达式,判断条件更复杂一些:
触发兜底的三种情况
只要满足以下任意一个条件,就会触发兜底逻辑:
rewriteResult == null- 改写结果为空rewriteResult.getSubQuestions() == null- 子问题列表为 nullrewriteResult.getSubQuestions().isEmpty()- 子问题列表为空
付费内容提示
该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放
加入星球后,你可以获得:
- 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
- 讲解文档:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的详细文档
- 讲解视频:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
- 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
