[{"data":1,"prerenderedAt":2805},["ShallowReactive",2],{"search-docs":3,"doc-\u002Fai\u002Fagent\u002Fsubagents":886},[4,8,12,16,20,24,28,32,36,40,44,48,52,56,60,64,68,72,76,80,84,88,92,96,100,104,108,112,116,120,124,128,132,136,140,144,148,152,156,159,162,165,169,172,175,178,182,186,190,194,198,202,206,210,214,218,222,226,230,234,238,242,246,250,254,258,262,266,269,273,277,281,285,288,291,294,298,301,304,307,310,313,316,319,322,325,329,332,336,340,344,348,352,356,359,362,365,368,371,374,377,380,383,386,389,393,396,399,402,405,408,411,414,417,420,424,428,432,435,438,442,446,450,454,458,462,466,470,474,477,480,483,487,491,494,497,500,504,507,511,515,518,521,524,527,530,533,536,539,542,545,548,551,554,557,560,563,566,569,572,575,579,583,587,591,595,599,603,606,610,614,617,620,623,626,629,633,637,640,643,646,649,652,655,658,661,664,667,670,673,676,679,682,685,688,691,694,697,700,703,706,709,712,716,720,724,728,732,736,740,744,748,752,756,760,764,768,772,775,779,783,787,790,793,796,799,802,805,808,811,814,818,822,825,829,832,835,838,841,844,848,851,854,858,862,865,869,873,876,879,882],{"path":5,"title":6,"description":7},"\u002Fabout\u002Fauthor","作者相关","只想纯粹的做一个程序员...",{"path":9,"title":10,"description":11},"\u002Fabout\u002Fjourney","心路历程","",{"path":13,"title":14,"description":15},"\u002Fai\u002Fagent\u002Fframeworks","Agent 框架","主流 Agent 框架：LangChain、LlamaIndex、AutoGen、CrewAI",{"path":17,"title":18,"description":19},"\u002Fai\u002Fagent\u002Fhooks","Agent Hooks 与自动化","Claude Agent 的 Hooks 生命周期、事件类型、典型自动化场景",{"path":21,"title":22,"description":23},"\u002Fai\u002Fagent\u002Fintroduction","AI Agent 概述","AI Agent 核心概念：感知、规划、执行、记忆",{"path":25,"title":26,"description":27},"\u002Fai\u002Fagent\u002Fpractice","Agent 实战","AI Agent 实战：构建自主任务执行系统",{"path":29,"title":30,"description":31},"\u002Fai\u002Fagent\u002Fsdk","Claude Agent SDK 开发","使用 Claude Agent SDK 构建自定义 AI Agent：架构、API、生命周期",{"path":33,"title":34,"description":35},"\u002Fai\u002Fagent\u002Fsubagents","Subagents 子代理","用 Subagents 分解复杂任务、并发执行、隔离上下文",{"path":37,"title":38,"description":39},"\u002Fai\u002Fagent\u002Ftool-use","工具调用","AI Agent 工具调用：Function Calling、Tool Use 原理与实践",{"path":41,"title":42,"description":43},"\u002Fai\u002Ffundamentals\u002Fdeep-learning","深度学习入门","深度学习基础知识：前向传播、反向传播、损失函数、优化器",{"path":45,"title":46,"description":47},"\u002Fai\u002Ffundamentals\u002Fml-basics","机器学习基础","机器学习核心概念：监督学习、无监督学习、强化学习",{"path":49,"title":50,"description":51},"\u002Fai\u002Ffundamentals\u002Fneural-networks","神经网络原理","神经网络架构：CNN、RNN、注意力机制",{"path":53,"title":54,"description":55},"\u002Fai\u002Fgetting-started","AI 学习路线","AI 技术学习路线图，从基础到实战的完整指南",{"path":57,"title":58,"description":59},"\u002Fai\u002Fllm\u002Ffine-tuning","模型微调","大模型微调技术：LoRA、QLoRA、全量微调、RLHF",{"path":61,"title":62,"description":63},"\u002Fai\u002Fllm\u002Fintroduction","大模型概述","大语言模型发展历程、核心能力与主流模型对比",{"path":65,"title":66,"description":67},"\u002Fai\u002Fllm\u002Flocal-deploy","本地部署","大模型本地部署：Ollama、vLLM、llama.cpp",{"path":69,"title":70,"description":71},"\u002Fai\u002Fllm\u002Ftransformer","Transformer 架构","Transformer 架构详解：自注意力机制、位置编码、多头注意力",{"path":73,"title":74,"description":75},"\u002Fai\u002Fmcp\u002Fclient","MCP Client 开发","MCP Client 开发指南：连接、调用、集成",{"path":77,"title":78,"description":79},"\u002Fai\u002Fmcp\u002Fdebugging","MCP 调试与排错","MCP Server 开发与集成过程中的常见问题、日志分析、诊断工具",{"path":81,"title":82,"description":83},"\u002Fai\u002Fmcp\u002Fintroduction","MCP 概述","Model Context Protocol 协议概述：架构、核心概念、应用场景",{"path":85,"title":86,"description":87},"\u002Fai\u002Fmcp\u002Fserver","MCP Server 开发","MCP Server 开发指南：资源、工具、提示词的实现",{"path":89,"title":90,"description":91},"\u002Fai\u002Fmcp\u002Ftools","MCP Tools 深入","深入理解 MCP Tools：与 Resources\u002FPrompts 的差异、Schema 设计、Annotations 与权限控制",{"path":93,"title":94,"description":95},"\u002Fai\u002Fprompt\u002Fadvanced","高级 Prompt 模式","高级 Prompt 设计模式：Tree-of-Thought、自我反思、多轮对话策略",{"path":97,"title":98,"description":99},"\u002Fai\u002Fprompt\u002Fbasics","Prompt 基础","Prompt Engineering 入门：基本概念、角色设定、输出格式控制",{"path":101,"title":102,"description":103},"\u002Fai\u002Fprompt\u002Ftechniques","提示词技巧","常用提示词技巧：Few-shot、Chain-of-Thought、ReAct",{"path":105,"title":106,"description":107},"\u002Fai\u002Frag\u002Fembedding","文本嵌入","文本嵌入模型：Embedding 原理、模型选择、相似度计算",{"path":109,"title":110,"description":111},"\u002Fai\u002Frag\u002Fintroduction","RAG 概述","检索增强生成（RAG）架构原理、优势与应用场景",{"path":113,"title":114,"description":115},"\u002Fai\u002Frag\u002Fpractice","RAG 实战","RAG 应用实战：文档问答系统、知识库搭建",{"path":117,"title":118,"description":119},"\u002Fai\u002Frag\u002Fvector-database","向量数据库","主流向量数据库对比：Milvus、Pinecone、Chroma、Weaviate",{"path":121,"title":122,"description":123},"\u002Fai\u002Fskills\u002Fbest-practices","Skill 最佳实践","编写高质量 Skill 的设计原则、常见陷阱与优化技巧",{"path":125,"title":126,"description":127},"\u002Fai\u002Fskills\u002Fcreating","创建自定义 Skill","从零编写一个可被 Agent 自动发现和调用的 Skill",{"path":129,"title":130,"description":131},"\u002Fai\u002Fskills\u002Fintroduction","Agent Skills 概述","Claude Agent Skills 概念、工作原理、与 Tools\u002FMCP 的区别",{"path":133,"title":134,"description":135},"\u002Fgolang\u002Fadvanced\u002Fconcurrency","Go - 并发深入","深入理解 Go 并发编程的核心机制。",{"path":137,"title":138,"description":139},"\u002Fgolang\u002Fadvanced\u002Fgc","Go - 垃圾回收","理解 Go 的垃圾回收机制，掌握 GC 调优方法。",{"path":141,"title":142,"description":143},"\u002Fgolang\u002Fadvanced\u002Fgmp","Go - GMP 调度模型","GMP 是 Go 运行时调度器的核心模型，理解它对于编写高性能 Go 程序至关重要。",{"path":145,"title":146,"description":147},"\u002Fgolang\u002Fadvanced\u002Fgo-concurrency","Go - 并发编程","Go 的并发是其核心特性之一，通过 Goroutine 和 Channel 实现。",{"path":149,"title":150,"description":151},"\u002Fgolang\u002Fadvanced\u002Fmemory","Go - 内存模型","理解 Go 的内存分配机制和内存模型。",{"path":153,"title":154,"description":155},"\u002Fgolang\u002Fadvanced\u002Fprofiling","Go - 性能分析","掌握 Go 的性能分析工具：pprof、trace、benchmark。",{"path":157,"title":158,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-basic","Go - 基础语法",{"path":160,"title":161,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-composite","Go - 复合类型",{"path":163,"title":164,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-control","Go - 流程控制",{"path":166,"title":167,"description":168},"\u002Fgolang\u002Fcore\u002Fgo-error","Go - 错误处理","Go 使用显式的错误返回值来处理错误，而不是异常机制。",{"path":170,"title":171,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-function","Go - 函数",{"path":173,"title":174,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-install","Go - 环境搭建",{"path":176,"title":177,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-interface","Go - 接口",{"path":179,"title":180,"description":181},"\u002Fgolang\u002Fcore\u002Fgo-module","Go - 包管理","Go Modules 是 Go 1.11 引入的官方依赖管理方案，Go 1.16 后成为默认模式。",{"path":183,"title":184,"description":185},"\u002Fgolang\u002Fdistributed\u002Fgrpc","Go - gRPC","gRPC 是 Google 开发的高性能 RPC 框架，使用 Protocol Buffers 作为序列化协议。",{"path":187,"title":188,"description":189},"\u002Fgolang\u002Fdistributed\u002Fmicroservice","Go - 微服务","微服务架构的核心组件：服务发现、负载均衡、熔断降级。",{"path":191,"title":192,"description":193},"\u002Fgolang\u002Fdistributed\u002Fmq","Go - 消息队列","使用 Go 操作 Kafka 和 RabbitMQ。",{"path":195,"title":196,"description":197},"\u002Fgolang\u002Fdistributed\u002Fredis","Go - Redis","使用 go-redis 操作 Redis，实现缓存、分布式锁等功能。",{"path":199,"title":200,"description":201},"\u002Fgolang\u002Fengineering\u002Fconfig","Go - 配置管理","使用 viper 进行配置管理，支持多种配置格式和配置中心。",{"path":203,"title":204,"description":205},"\u002Fgolang\u002Fengineering\u002Fdocker","Go - Docker 部署","使用 Docker 容器化部署 Go 应用。",{"path":207,"title":208,"description":209},"\u002Fgolang\u002Fengineering\u002Fkubernetes","Go - Kubernetes 部署","在 Kubernetes 上部署和管理 Go 应用。",{"path":211,"title":212,"description":213},"\u002Fgolang\u002Fengineering\u002Flogging","Go - 日志系统","使用 zap 和 logrus 构建高性能结构化日志系统。",{"path":215,"title":216,"description":217},"\u002Fgolang\u002Fengineering\u002Ftesting","Go - 单元测试","Go 内置了强大的测试框架，掌握测试是编写高质量代码的基础。",{"path":219,"title":220,"description":221},"\u002Fgolang\u002Fstdlib\u002Fbufio","bufio","在 Go 语言中，bufio 包提供了带缓冲的 I\u002FO 操作，能够提高读写性能。以下是一些常用的 bufio 包 API 及其详细说明：",{"path":223,"title":224,"description":225},"\u002Fgolang\u002Fstdlib\u002Fcontainer","container","在Go语言标准库中，container 包提供了几种常用的数据结构实现，这些数据结构对于高效地管理和操作数据非常有用。以下是 container 包中主要的数据结构：",{"path":227,"title":228,"description":229},"\u002Fgolang\u002Fstdlib\u002Fcrypto","crypto","在 Go 语言中，crypto 包提供了一组用于加密和解密的功能。以下是一些常用的 crypto 包及其子包的 API 及其详细说明：",{"path":231,"title":232,"description":233},"\u002Fgolang\u002Fstdlib\u002Fencoding-csv","encoding\u002Fcsv","在 Go 语言中，encoding\u002Fcsv 包提供了对 CSV（逗号分隔值）文件进行读写的功能。以下是一些常用的 encoding\u002Fcsv 包的 API 及其详细说明：",{"path":235,"title":236,"description":237},"\u002Fgolang\u002Fstdlib\u002Fencoding-json","encoding\u002Fjson","在 Go 语言中，encoding\u002Fjson 包提供了对 JSON 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fjson 包的 API 及其详细说明：",{"path":239,"title":240,"description":241},"\u002Fgolang\u002Fstdlib\u002Fencoding-xml","encoding\u002Fxml","在 Go 语言中，encoding\u002Fxml 包提供了对 XML 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fxml 包的 API 及其详细说明：",{"path":243,"title":244,"description":245},"\u002Fgolang\u002Fstdlib\u002Fflag","flag","在Go语言中，flag 包是用于处理命令行参数的标准库，它提供了一种简单而直接的方式来解析和使用命令行参数。下面是关于 flag 包的一些基本介绍和常用功能：",{"path":247,"title":248,"description":249},"\u002Fgolang\u002Fstdlib\u002Ffmt","fmt","在 Go 语言的标准库中，fmt 包是非常重要的，它提供了处理格式化输入和输出的基本工具。以下是一些 fmt 包内常用的API：",{"path":251,"title":252,"description":253},"\u002Fgolang\u002Fstdlib\u002Fhttp","net\u002Fhttp","在 Go 语言中，net\u002Fhttp 包提供了用于构建 HTTP 客户端和服务器的强大工具。以下是一些常用的 net\u002Fhttp 包的 API 及其详细说明：",{"path":255,"title":256,"description":257},"\u002Fgolang\u002Fstdlib\u002Fio","io","在 Go 语言中，io 包提供了基本的输入输出功能。以下是一些常用的 io 包的 API 及其详细说明：",{"path":259,"title":260,"description":261},"\u002Fgolang\u002Fstdlib\u002Flog","log","在 Go 语言中，log 包提供了简单的日志记录功能。以下是一些常用的 log 包的 API 及其详细说明：",{"path":263,"title":264,"description":265},"\u002Fgolang\u002Fstdlib\u002Fmath","math","在 Go 语言中，math 包提供了基本的数学函数和常量。以下是一些常用的 math 包的 API 及其详细说明：",{"path":267,"title":268,"description":11},"\u002Fgolang\u002Fstdlib\u002Fnet","net",{"path":270,"title":271,"description":272},"\u002Fgolang\u002Fstdlib\u002Fos","os","在Go语言中，os 包是一个非常重要且常用的标准库，它提供了与操作系统交互的功能，包括文件操作、环境变量管理、进程管理等。下面是一些 os 包中常用的功能和API：",{"path":274,"title":275,"description":276},"\u002Fgolang\u002Fstdlib\u002Fsort","order","在 Go 语言中，sort 包提供了对切片和用户定义的集合进行排序的函数。它实现了常见的排序算法，如快速排序（Quicksort）和堆排序（Heapsort），并且为自定义集合提供了接口，使得用户可以根据特定的需求进行排序。",{"path":278,"title":279,"description":280},"\u002Fgolang\u002Fstdlib\u002Fstrconv","strconv","在 Go 语言中，strconv 包提供了字符串和基本数据类型之间的转换函数，例如将整数转换为字符串、字符串转换为整数，以及其他类型之间的转换。这些功能非常有用，特别是在处理用户输入或从外部数据源读取数据时。",{"path":282,"title":283,"description":284},"\u002Fgolang\u002Fstdlib\u002Ftime","time","在 Go 语言中，time 包提供了处理时间和日期的功能。以下是一些常用的 time 包的 API 及其详细说明：",{"path":286,"title":287,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ferror","Gin - 错误处理",{"path":289,"title":290,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ffile","Gin - 文件处理",{"path":292,"title":293,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fmiddleware","Gin - 中间件",{"path":295,"title":296,"description":297},"\u002Fgolang\u002Fweb\u002Fgin\u002Fquickstart","Gin - 快速开始","Gin 是目前最流行的 Go Web 框架，以高性能和简洁 API 著称。",{"path":299,"title":300,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frequest","Gin - 请求处理",{"path":302,"title":303,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fresponse","Gin - 响应处理",{"path":305,"title":306,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frouter","Gin - 路由",{"path":308,"title":309,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fvalidation","Gin - 参数校验",{"path":311,"title":312,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fassociation","GORM - 关联关系",{"path":314,"title":315,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fcrud","GORM - CRUD 操作",{"path":317,"title":318,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fmodel","GORM - 模型定义",{"path":320,"title":321,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fperformance","GORM - 日志与性能",{"path":323,"title":324,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquery","GORM - 高级查询",{"path":326,"title":327,"description":328},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquickstart","GORM - 快速开始","GORM 是 Go 语言最流行的 ORM 库，功能强大，使用简单。",{"path":330,"title":331,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Ftransaction","GORM - 事务与 Hook",{"path":333,"title":334,"description":335},"\u002Finterview\u002Fbasic","计算机基础面经","本章节汇总了面试中常见的通用技术概念，不局限于特定语言或数据库，是考察技术内功的关键考点。",{"path":337,"title":338,"description":339},"\u002Finterview\u002Fgolang","Golang 面试题","Go 语言面试高频考点，覆盖基础语法、数据结构、并发编程、内存管理、GC、调度器等核心知识。",{"path":341,"title":342,"description":343},"\u002Finterview\u002Fk8s","Kubernetes 面试题","Kubernetes（K8s）面试高频考点，覆盖架构原理、核心资源、网络存储、调度策略、运维监控等核心知识。",{"path":345,"title":346,"description":347},"\u002Finterview\u002Fmysql","MySQL 面试题","MySQL 数据库面试高频考点，覆盖索引、事务、锁、优化、主从复制等核心知识。",{"path":349,"title":350,"description":351},"\u002Finterview\u002Fredis","Redis 面试题","Redis 面试高频考点，覆盖数据结构、持久化、集群、缓存一致性、性能优化等核心知识。",{"path":353,"title":354,"description":355},"\u002Finterview\u002Frocketmq","RocketMQ 面试题","RocketMQ 面试高频考点，覆盖消息模型、可靠性、顺序消息、事务消息、存储与高可用等核心知识。",{"path":357,"title":358,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-arraylist","List - ArrayList 源码解析",{"path":360,"title":361,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-linkedlist","List - LinkedList 源码解析",{"path":363,"title":364,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-stack","List - Satck源码解析",{"path":366,"title":367,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-vectore","List - Vector 源码解析",{"path":369,"title":370,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-hashmap","Map - HashMap 源码解析",{"path":372,"title":373,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-linkedhashmap","Map - LinkedHashMap 源码解析",{"path":375,"title":376,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-treemap","Map - TreeMap 源码解析",{"path":378,"title":379,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-deque","Queue - Deque 接口解析",{"path":381,"title":382,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-queue","Queue - Queue 接口解析",{"path":384,"title":385,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-hashset","Set - HashSet源码解析",{"path":387,"title":388,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-linkedhashset","Set - LinkedHashSet 源码解析",{"path":390,"title":391,"description":392},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-treeset","Set - TreeSet源码解析","TreeSet 是一个 Set 集合接口的实现类，与 HashSet 类似，其底层也是通过维护了一个 TreeMap 对象来封装了一些实现方法，故本篇不再对 TreeSet 的底层原理进行详细说明，仅对常用 API 做简单介绍，如需了解 TreeMap 的底层实现原理，请移步 Map - HashMap 源码解析",{"path":394,"title":395,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fannotation","Java核心 - 注解",{"path":397,"title":398,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fbasic-grammar","Java核心 - 基础语法",{"path":400,"title":401,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fclass-and-object","Java核心 - 面向对象",{"path":403,"title":404,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fcommon-classes","Java核心 - 常用类",{"path":406,"title":407,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fexception","Java核心 - 异常处理",{"path":409,"title":410,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fgenerics","Java核心 - 泛型",{"path":412,"title":413,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fjdk-env-path","Java核心 - 环境搭建",{"path":415,"title":416,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Freflection","Java核心 - 反射",{"path":418,"title":419,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fstring","Java核心 - String 字符串",{"path":421,"title":422,"description":423},"\u002Fother\u002Fjava\u002Fio\u002Fbuffer-stream","Java IO - 缓冲流","缓冲流是对基本流的包装，通过内置缓冲区减少系统调用次数，大幅提升读写效率。",{"path":425,"title":426,"description":427},"\u002Fother\u002Fjava\u002Fio\u002Fbyte-stream","Java IO - 字节流","字节流是 Java IO 中最基本的流类型，以字节（byte）为单位进行数据读写，可以处理任意类型的文件。",{"path":429,"title":430,"description":431},"\u002Fother\u002Fjava\u002Fio\u002Fchar-stream","Java IO - 字符流","字符流以字符为单位进行读写，专门用于处理文本文件。相比字节流，字符流能够正确处理字符编码，避免中文乱码问题。",{"path":433,"title":434,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Ffile","Java IO - File 类",{"path":436,"title":437,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Fio-stream-system","Java IO - IO流概述",{"path":439,"title":440,"description":441},"\u002Fother\u002Fjava\u002Fio\u002Fnio","Java IO - NIO","NIO（New IO）是 JDK 1.4 引入的新 IO 模型，提供了更高效的 IO 操作方式，支持非阻塞 IO 和多路复用。",{"path":443,"title":444,"description":445},"\u002Fother\u002Fjava\u002Fjvm\u002Fclass-loading","类加载机制","类加载机制是 JVM 将 .class 文件加载到内存，并对数据进行校验、转换解析和初始化，最终形成可被 JVM 直接使用的 Java 类型的过程。",{"path":447,"title":448,"description":449},"\u002Fother\u002Fjava\u002Fjvm\u002Fgarbage-collection","垃圾回收","垃圾回收（Garbage Collection，GC）是 JVM 自动管理内存的机制，负责回收不再使用的对象所占用的内存。",{"path":451,"title":452,"description":453},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-memory","JVM 内存结构","JVM 在执行 Java 程序时，会把它管理的内存划分为若干个不同的数据区域。这些区域有各自的用途、创建和销毁时间。",{"path":455,"title":456,"description":457},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-tuning","JVM 调优","JVM 调优是优化 Java 应用性能的重要手段，主要包括参数配置、性能监控和问题排查。",{"path":459,"title":460,"description":461},"\u002Fother\u002Fjava\u002Fthread\u002Fatomic","原子类","Java 原子类（Atomic Classes）提供了一种无锁的线程安全方式，基于 CAS（Compare-And-Swap）操作实现。",{"path":463,"title":464,"description":465},"\u002Fother\u002Fjava\u002Fthread\u002Fcompletable-future","CompletableFuture","CompletableFuture 是 JDK 8 引入的异步编程工具，实现了 Future 和 CompletionStage 接口，支持函数式编程和链式调用。",{"path":467,"title":468,"description":469},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-collections","并发集合","Java 并发包提供了多种线程安全的集合类，用于替代传统的同步集合（如 Collections.synchronizedList）。",{"path":471,"title":472,"description":473},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-utils","并发工具类","Java 并发包提供了多种实用的并发工具类，用于控制线程之间的协调与同步。",{"path":475,"title":476,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fsynchronized-lock","同步机制",{"path":478,"title":479,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-basic","线程基础",{"path":481,"title":482,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-pool","线程池",{"path":484,"title":485,"description":486},"\u002Fother\u002Fspring-series\u002Fspring\u002Fannotations-beans","Spring - 基于注解管理Bean","从 Java 5 开始，Java 增加了对注解（Annotation）的支持，它是代码中的一种特殊标记，可以在编译、类加载和运行时被读取，执行相应的处理。开发人员可以通过注解在不改变原有代码和逻辑的情况下，在源代码中嵌入补充信息。",{"path":488,"title":489,"description":490},"\u002Fother\u002Fspring-series\u002Fspring\u002Fimplement-ioc","Spring - 原理手写IoC","Spring 框架的 IOC 是基于 Java 反射机制实现的，在学习手写 IoC 之前，你需要具备一定的 Java 反射相关的知识，参考本站内的 Java 教程。",{"path":492,"title":493,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fintroduction-case","Spring - 入门案例",{"path":495,"title":496,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aop","Spring - 面向切面AOP",{"path":498,"title":499,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aot","Spring - AOT提前编译",{"path":501,"title":502,"description":503},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-data-validation","Spring - 数据校验","在开发中，我们经常遇到参数校验的需求，比如用户注册的时候，要校验用户名不能为空、用户名长度不超过20个字符、手机号是合法的手机号格式等等。如果使用普通方式，我们会把校验的代码和真正的业务处理逻辑耦合在一起，而且如果未来要新增一种校验逻辑也需要在修改多个地方。而spring validation允许通过注解的方式来定义对象校验规则，把校验和业务逻辑分离开，让代码编写更加方便。Spring Validation其实就是对Hibernate Validator进一步的封装，方便在Spring中使用。",{"path":505,"title":506,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-i18n","Spring - 国际化i18n",{"path":508,"title":509,"description":510},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-ioc","Spring - IOC容器","IoC 是 Inversion of Control 的简写，译为“控制反转”，它不是一门技术，而是一种设计思想，是一个重要的面向对象编程法则，能够指导我们如何设计出松耦合、更优良的程序。",{"path":512,"title":513,"description":514},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-junit","Spring - 单元测试JUnit","在之前的测试方法中，几乎都能看到以下的两行代码：",{"path":516,"title":517,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-resources","Spring - 资源操作",{"path":519,"title":520,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-summarize","Spring - Spring概述",{"path":522,"title":523,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-transaction","Spring - 事务",{"path":525,"title":526,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fxml-beans","Spring - 基于XML管理Bean",{"path":528,"title":529,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-config","SpringBoot - 配置详解",{"path":531,"title":532,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-data","SpringBoot - 数据访问",{"path":534,"title":535,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-quickstart","SpringBoot - 快速入门",{"path":537,"title":538,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-web","SpringBoot - Web 开发",{"path":540,"title":541,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-config","SpringCloud - 配置中心",{"path":543,"title":544,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-discovery","SpringCloud - 服务注册与发现",{"path":546,"title":547,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-feign","SpringCloud - 服务调用",{"path":549,"title":550,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-gateway","SpringCloud - 服务网关",{"path":552,"title":553,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-introduction","SpringCloud - 微服务概述",{"path":555,"title":556,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-sentinel","SpringCloud - 服务保护",{"path":558,"title":559,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-databind","SpringMVC - 数据绑定与转换",{"path":561,"title":562,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-exception","SpringMVC - 异常处理",{"path":564,"title":565,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-interceptor","SpringMVC - 拦截器",{"path":567,"title":568,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-introduction","SpringMVC - 简介与环境搭建",{"path":570,"title":571,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-request","SpringMVC - 请求处理",{"path":573,"title":574,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-response","SpringMVC - 响应处理",{"path":576,"title":577,"description":578},"\u002Fproject\u002Frocket-leaf\u002Farchitecture","项目架构","Rocket-Leaf 的目录结构、模块划分、数据流向，以及各层之间的依赖关系。",{"path":580,"title":581,"description":582},"\u002Fproject\u002Frocket-leaf\u002Fbackend-layers","后端分层设计","Rocket-Leaf 的 model \u002F rocketmq \u002F service 三层结构，以及服务之间的依赖关系与设计取舍。",{"path":584,"title":585,"description":586},"\u002Fproject\u002Frocket-leaf\u002Fclient-manager","RocketMQ 客户端管理器","AdminClientManager 的多客户端池、默认连接懒加载、自动重连重试的设计与实现。",{"path":588,"title":589,"description":590},"\u002Fproject\u002Frocket-leaf\u002Fencryption","连接信息加密存储","AES-256-GCM + SHA-256 字段级派生密钥的实现，以及如何在不破坏兼容性的前提下为历史明文数据做透明迁移。",{"path":592,"title":593,"description":594},"\u002Fproject\u002Frocket-leaf\u002Ffrontend","前端结构与类型绑定","React + Vite 目录组织、自动生成的 Wails 绑定、api 薄封装与自定义 hooks 的职责划分。",{"path":596,"title":597,"description":598},"\u002Fproject\u002Frocket-leaf","项目简介","Rocket-Leaf 是一款基于 Wails v3 构建的跨平台 RocketMQ 桌面管理客户端，Go 后端 + React 前端。本文档系列拆解它的架构与关键实现。",{"path":600,"title":601,"description":602},"\u002Fproject\u002Frocket-leaf\u002Fwails-v3","Wails v3 入门","Wails v3 的核心概念、Service 绑定机制，以及 Rocket-Leaf 是如何用它把 Go 后端和 React 前端打通的。",{"path":604,"title":605,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-basic","Docker - 入门基础",{"path":607,"title":608,"description":609},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-compose","Docker - Compose","在部署应用时，常常使用到不止一个容器，那么在部署容器的时候就需要一个一个进行部署，这样的部署过程也相对来说比较繁琐复杂，也容易出问题，那么有没有一种更为简单的方法呢？",{"path":611,"title":612,"description":613},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-container-connection","Docker - 容器互联","在上一个章节中我们学习了 Docker 容器的端口映射，可以将 Docker 容器和本地以及网络中的端口进行连接起来。",{"path":615,"title":616,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-dockerfile","Docker - Dockerfile",{"path":618,"title":619,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-helloworld","Docker - HelloWorld",{"path":621,"title":622,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-install","Docker - 安装",{"path":624,"title":625,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-introduce","Docker - 简介",{"path":627,"title":628,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-object","Docker - 镜像、容器、仓库",{"path":630,"title":631,"description":632},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-warehouse","Docker - 仓库管理","仓库是集中存放资源的地方，代码仓库是存放代码的，那么Docker 中的仓库就是存放 Docker 镜像的。",{"path":634,"title":635,"description":636},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-web-containers","Docker - WEB应用实例","在之前的章节中，仅对普通容器进行了演示，但在实际中常常使用到 Docker 容器中的 WEB 应用程序。",{"path":638,"title":639,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-config","Kubernetes - ConfigMap 与 Secret",{"path":641,"title":642,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm","Kubernetes - Helm 包管理",{"path":644,"title":645,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-install","Kubernetes - 集群安装",{"path":647,"title":648,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-introduction","Kubernetes - 简介与架构",{"path":650,"title":651,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-kubectl","Kubernetes - kubectl 命令行工具",{"path":653,"title":654,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-monitoring","Kubernetes - 监控与日志",{"path":656,"title":657,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-network-security","Kubernetes - 网络与安全",{"path":659,"title":660,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-service","Kubernetes - Service 与 Ingress",{"path":662,"title":663,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-storage","Kubernetes - 持久化存储",{"path":665,"title":666,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-workload","Kubernetes - 工作负载资源",{"path":668,"title":669,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-bash","Linux - Bash 基础语法",{"path":671,"title":672,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-file-directory","Linux - 文件与目录操作",{"path":674,"title":675,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-network","Linux - 网络配置",{"path":677,"title":678,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-package","Linux - 软件包管理",{"path":680,"title":681,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-process","Linux - 进程管理",{"path":683,"title":684,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-scripts","Linux - 常用脚本示例",{"path":686,"title":687,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-service","Linux - 服务管理",{"path":689,"title":690,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission","Linux - 用户与权限管理",{"path":692,"title":693,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-https","Nginx - HTTPS 配置",{"path":695,"title":696,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install","Nginx - 安装与配置",{"path":698,"title":699,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-loadbalance","Nginx - 负载均衡",{"path":701,"title":702,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-optimization","Nginx - 性能优化",{"path":704,"title":705,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-proxy","Nginx - 反向代理",{"path":707,"title":708,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-static","Nginx - 静态资源服务",{"path":710,"title":711,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-vhost","Nginx - 虚拟主机配置",{"path":713,"title":714,"description":715},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-architecture","MySQL 高可用架构","主从复制、读写分离、分库分表。",{"path":717,"title":718,"description":719},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-index","MySQL 索引","索引是帮助 MySQL 高效获取数据的有序数据结构。",{"path":721,"title":722,"description":723},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-lock","MySQL 锁","锁用于解决并发访问时的数据一致性问题。",{"path":725,"title":726,"description":727},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-optimize","MySQL 性能优化","SQL 优化是后端开发必备技能。",{"path":729,"title":730,"description":731},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-transaction","MySQL 事务","事务是一组不可分割的操作，要么全部成功，要么全部失败。",{"path":733,"title":734,"description":735},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-advanced","SQL 进阶","多表查询、子查询、函数、视图、存储过程。",{"path":737,"title":738,"description":739},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic","SQL 基础","SQL（Structured Query Language）是操作关系型数据库的标准语言。",{"path":741,"title":742,"description":743},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-advanced","Redis 进阶功能","事务、发布订阅、Lua 脚本、Pipeline。",{"path":745,"title":746,"description":747},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-basic","Redis 基础","Redis 安装配置与基本命令。",{"path":749,"title":750,"description":751},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-cluster","Redis 高可用","主从复制、哨兵、Cluster 集群。",{"path":753,"title":754,"description":755},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-datatype","Redis 数据类型","Redis 5 种基本数据类型 + 4 种特殊类型。",{"path":757,"title":758,"description":759},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-optimize","Redis 性能优化","内存优化、缓存问题、最佳实践。",{"path":761,"title":762,"description":763},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-persistence","Redis 持久化","Redis 提供 RDB 和 AOF 两种持久化方式。",{"path":765,"title":766,"description":767},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-principle","Redis 底层原理","数据结构、线程模型、网络模型。",{"path":769,"title":770,"description":771},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fbehaiver-patterns\u002Fobserver-pattern","观察者模式","观察者模式属于行为型模式，定义了对象之间的一对多的依赖关系，在这种模式中，当一个对象的状态发生变化时，所有依赖于它的对象都会得到通知，并且执行相关操作。观察者模式又被成为“发布—订阅模式”，即发布者发生改变后，会通知所有订阅者。",{"path":773,"title":774,"description":11},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Ffactory-pattern","工厂模式",{"path":776,"title":777,"description":778},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Fsingleton-pattern","单例模式","单例模式是最常用的设计模式之一，他可以保证在整个应用中，某个类只存在一个实例化对象，即全局使用到该类的只有一个对象，这种模式在需要限制某些类的实例数量时非常有用，通常全局只需要一个该对象即可，如一些配置文件映射对象、数据库连接对象等。",{"path":780,"title":781,"description":782},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fstructural-patterns\u002Fadapter-pattern","适配器模式","适配器模式是一种结构型模式，可以将一个类的接口转换成客户端所期望的另一种接口，适配器模式可以帮助开发人员在不修改现有代码的情况下，将不兼容的类组合在一起。",{"path":784,"title":785,"description":786},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-basic-operations","Git 创建版本库","在 Git 上创建版本库有两种方式，一种是直接拷贝远程 Git 仓库到本地，另外一种是我们自己创建本地的版本库。",{"path":788,"title":789,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-branch-manage","Git 分支管理",{"path":791,"title":792,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-content-operations","Git 仓库内容操作",{"path":794,"title":795,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-introduce-install","Git 介绍和安装",{"path":797,"title":798,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-remote-manage","Git 远程管理",{"path":800,"title":801,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-workspace-index-repo","Git 工作原理",{"path":803,"title":804,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fhomebrew","HomeBrew 教程",{"path":806,"title":807,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fidea\u002Fshortcuts","快捷键",{"path":809,"title":810,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fmaven\u002Fintroduce-install-config","Maven - 介绍、安装、配置",{"path":812,"title":813,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fbasic-knowledge","2. 基础知识",{"path":815,"title":816,"description":817},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomponent-communication","9. 组件通信","在前面的章节内，介绍了 Vue 中最核心的内容——组件的介绍和使用，和 Java 等编程语言相反，组件并不近似于这些变成语言中的类，类可以通过类或者其实例化的对象来相互交互，但 Vue 组件之间的作用域是相互独立的，这就意味着不同组件之间的数据无法相互引用。",{"path":819,"title":820,"description":821},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomputed","4. 计算属性","虽然直接在模板中使用表达式方便，但是如果在模板中添加很多逻辑，会让模板变的臃肿且难维护，耦合度较高。有没有一种简单的方式来实现呢？答案是有的。",{"path":823,"title":824,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcreate-vue-project","1. 环境搭建及安装",{"path":826,"title":827,"description":828},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Flife-cycle","6. 生命周期","生命周期是指组件从创建、挂载、更新到销毁的整个过程中所经历的一系列阶段。在 Vue 中，每个组件都有自己的生命周期，可以通过生命周期钩子函数来监听和处理组件在不同阶段的行为和状态。",{"path":830,"title":831,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fother-api","10. 其他 API",{"path":833,"title":834,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fpinia","8. Pinia",{"path":836,"title":837,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter","7. 路由",{"path":839,"title":840,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar","3. 指令及模板语法",{"path":842,"title":843,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fvue3-new-component","11. Vue3 新组件",{"path":845,"title":846,"description":847},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fwatch","5. 监视","Watch 是 Vue 提供的一个用于监视响应式数据变化并执行相应操作的 API，能够对响应式数据的变化做出一些操作的功能。Vue3 中的 Watch 支持多种用法，包括监视响应式对象、ref 对象、数组、函数等。",{"path":849,"title":850,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-introduction","Kafka 简介与安装",{"path":852,"title":853,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-producer-consumer","Kafka 生产者与消费者",{"path":855,"title":856,"description":857},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-springboot","Spring Boot 整合 Kafka","Spring Kafka 提供了对 Apache Kafka 的便捷集成。",{"path":859,"title":860,"description":861},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-exchange","RabbitMQ Exchange 详解","Exchange（交换机）是 RabbitMQ 的核心组件，负责接收生产者发送的消息，并根据规则将消息路由到一个或多个队列。",{"path":863,"title":864,"description":11},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-introduction","RabbitMQ 简介与安装",{"path":866,"title":867,"description":868},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-reliability","RabbitMQ 消息可靠性","消息可靠性是消息队列的核心要求，RabbitMQ 提供了多种机制来保证消息不丢失。",{"path":870,"title":871,"description":872},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-springboot","Spring Boot 整合 RabbitMQ","Spring AMQP 提供了对 RabbitMQ 的便捷集成，大大简化了开发工作。",{"path":874,"title":875,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-client","RocketMQ 客户端使用",{"path":877,"title":878,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-concepts","RocketMQ 核心概念",{"path":880,"title":881,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-installation","RocketMQ 安装部署",{"path":883,"title":884,"description":885},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-message-type","RocketMQ 消息类型","RocketMQ 支持多种消息类型，满足不同业务场景需求。",{"id":887,"title":34,"body":888,"description":35,"extension":2800,"meta":2801,"navigation":1102,"path":33,"seo":2802,"stem":2803,"__hash__":2804},"docs\u002Fai\u002Fagent\u002Fsubagents.md",{"type":889,"value":890,"toc":2758},"minimark",[891,896,904,932,943,947,952,955,966,973,977,980,984,995,998,1002,1005,1009,1016,1163,1170,1174,1406,1412,1415,1425,1499,1518,1525,1528,1532,1584,1588,1670,1677,1681,1687,1690,1702,1708,1712,1715,1829,1833,1836,1839,1869,1872,1875,1889,1895,1898,1901,1905,1979,1983,1986,2022,2026,2029,2032,2036,2039,2047,2051,2058,2062,2069,2073,2083,2087,2162,2165,2169,2172,2263,2267,2270,2335,2338,2341,2355,2359,2362,2668,2671,2686,2689,2692,2717,2720,2737,2754],[892,893,895],"h2",{"id":894},"什么是-subagent","什么是 Subagent",[897,898,899,903],"p",{},[900,901,902],"strong",{},"Subagent（子代理）"," 是由主 Agent 通过工具调用创建的、拥有独立上下文的子任务 Agent。它的核心特点：",[905,906,907,914,920,926],"ul",{},[908,909,910,913],"li",{},[900,911,912],{},"独立上下文","：子代理有自己的消息历史，不污染父 Agent",[908,915,916,919],{},[900,917,918],{},"任务隔离","：失败\u002F超时影响仅限子代理",[908,921,922,925],{},[900,923,924],{},"可并发","：多个 subagent 可并行执行",[908,927,928,931],{},[900,929,930],{},"可专业化","：不同 subagent 可配置不同模型、工具、系统提示",[933,934,940],"pre",{"className":935,"code":937,"language":938,"meta":939},[936],"language-text","flowchart TD\n    Main[\"主 Agent\u003Cbr\u002F>（协调者）\"]\n    Main --> Sub1[\"Subagent A\u003Cbr\u002F>研究信息\"]\n    Main --> Sub2[\"Subagent B\u003Cbr\u002F>写代码\"]\n    Main --> Sub3[\"Subagent C\u003Cbr\u002F>跑测试\"]\n    Sub1 --> R1[\"结果\"]\n    Sub2 --> R2[\"结果\"]\n    Sub3 --> R3[\"结果\"]\n    R1 --> Main\n    R2 --> Main\n    R3 --> Main\n    Main --> Final[\"汇总产出\"]\n","text","mermaid",[941,942,937],"code",{"__ignoreMap":11},[892,944,946],{"id":945},"为什么需要-subagents","为什么需要 Subagents",[948,949,951],"h3",{"id":950},"问题-1上下文爆炸","问题 1：上下文爆炸",[897,953,954],{},"大任务需要读 50 个文件才能给出结论。如果全塞到主 Agent 里：",[905,956,957,960,963],{},[908,958,959],{},"上下文飙升，成本高",[908,961,962],{},"细节过多容易分散注意力",[908,964,965],{},"后续轮次被 \"历史负担\" 拖慢",[897,967,968,969,972],{},"用 subagent：\"你去读那 50 个文件，然后告诉我一个总结\"——",[900,970,971],{},"只把结论带回主 Agent","。",[948,974,976],{"id":975},"问题-2串行太慢","问题 2：串行太慢",[897,978,979],{},"\"收集 A \u002F 收集 B \u002F 收集 C\" 三件事如果串行做，每件 20 秒就 1 分钟。并行 subagent 能把时间压到 ~20 秒。",[948,981,983],{"id":982},"问题-3专业化需求","问题 3：专业化需求",[905,985,986,989,992],{},[908,987,988],{},"\"代码审查\"需要严格的 instructions",[908,990,991],{},"\"写产品文案\"需要创意风格",[908,993,994],{},"\"执行 Bash 命令\"需要受限权限",[897,996,997],{},"一个 prompt 很难同时扮演好所有角色。subagent 让每个子任务有自己的\"人格\"。",[892,999,1001],{"id":1000},"subagent-的定义方式","Subagent 的定义方式",[897,1003,1004],{},"主流的两种定义方式：",[948,1006,1008],{"id":1007},"方式-1配置文件式claude-code-风格","方式 1：配置文件式（Claude Code 风格）",[897,1010,1011,1012,1015],{},"在 ",[941,1013,1014],{},".claude\u002Fagents\u002F"," 下放 markdown：",[933,1017,1021],{"className":1018,"code":1019,"language":1020,"meta":11,"style":11},"language-markdown shiki shiki-themes github-light github-light github-dark","---\nname: code-reviewer\ndescription: >-\n  Use this agent to review code for quality, security, and best\n  practices. Returns structured feedback with actionable suggestions.\ntools: Read, Grep, Glob\nmodel: sonnet\n---\n\nYou are a senior code reviewer. Focus on:\n\n1. Security vulnerabilities\n2. Performance issues\n3. Code smells\n4. Missing tests\n\nReturn your review as a bullet list, grouped by severity.\n","markdown",[941,1022,1023,1032,1046,1058,1064,1070,1081,1092,1097,1104,1110,1115,1125,1134,1143,1152,1157],{"__ignoreMap":11},[1024,1025,1028],"span",{"class":1026,"line":1027},"line",1,[1024,1029,1031],{"class":1030},"sxrX7","---\n",[1024,1033,1035,1039,1042],{"class":1026,"line":1034},2,[1024,1036,1038],{"class":1037},"sovSZ","name",[1024,1040,1041],{"class":1030},": ",[1024,1043,1045],{"class":1044},"sIIMD","code-reviewer\n",[1024,1047,1049,1052,1054],{"class":1026,"line":1048},3,[1024,1050,1051],{"class":1037},"description",[1024,1053,1041],{"class":1030},[1024,1055,1057],{"class":1056},"s8jYJ",">-\n",[1024,1059,1061],{"class":1026,"line":1060},4,[1024,1062,1063],{"class":1044},"  Use this agent to review code for quality, security, and best\n",[1024,1065,1067],{"class":1026,"line":1066},5,[1024,1068,1069],{"class":1044},"  practices. Returns structured feedback with actionable suggestions.\n",[1024,1071,1073,1076,1078],{"class":1026,"line":1072},6,[1024,1074,1075],{"class":1037},"tools",[1024,1077,1041],{"class":1030},[1024,1079,1080],{"class":1044},"Read, Grep, Glob\n",[1024,1082,1084,1087,1089],{"class":1026,"line":1083},7,[1024,1085,1086],{"class":1037},"model",[1024,1088,1041],{"class":1030},[1024,1090,1091],{"class":1044},"sonnet\n",[1024,1093,1095],{"class":1026,"line":1094},8,[1024,1096,1031],{"class":1030},[1024,1098,1100],{"class":1026,"line":1099},9,[1024,1101,1103],{"emptyLinePlaceholder":1102},true,"\n",[1024,1105,1107],{"class":1026,"line":1106},10,[1024,1108,1109],{"class":1030},"You are a senior code reviewer. Focus on:\n",[1024,1111,1113],{"class":1026,"line":1112},11,[1024,1114,1103],{"emptyLinePlaceholder":1102},[1024,1116,1118,1122],{"class":1026,"line":1117},12,[1024,1119,1121],{"class":1120},"sP4rz","1.",[1024,1123,1124],{"class":1030}," Security vulnerabilities\n",[1024,1126,1128,1131],{"class":1026,"line":1127},13,[1024,1129,1130],{"class":1120},"2.",[1024,1132,1133],{"class":1030}," Performance issues\n",[1024,1135,1137,1140],{"class":1026,"line":1136},14,[1024,1138,1139],{"class":1120},"3.",[1024,1141,1142],{"class":1030}," Code smells\n",[1024,1144,1146,1149],{"class":1026,"line":1145},15,[1024,1147,1148],{"class":1120},"4.",[1024,1150,1151],{"class":1030}," Missing tests\n",[1024,1153,1155],{"class":1026,"line":1154},16,[1024,1156,1103],{"emptyLinePlaceholder":1102},[1024,1158,1160],{"class":1026,"line":1159},17,[1024,1161,1162],{"class":1030},"Return your review as a bullet list, grouped by severity.\n",[897,1164,1165,1166,1169],{},"主 Agent 看到合适的任务就通过内置的 ",[941,1167,1168],{},"Agent"," 工具调用它。",[948,1171,1173],{"id":1172},"方式-2sdk-动态式","方式 2：SDK 动态式",[933,1175,1179],{"className":1176,"code":1177,"language":1178,"meta":11,"style":11},"language-ts shiki shiki-themes github-light github-light github-dark","import { query } from \"@anthropic-ai\u002Fclaude-agent-sdk\"\n\nasync function codeReviewSubagent(file: string) {\n  const result = query({\n    prompt: `Review the file at ${file}`,\n    options: {\n      systemPrompt: \"You are a senior code reviewer...\",\n      allowedTools: [\"Read\", \"Grep\"],\n      model: \"claude-sonnet-4-5\",\n      maxTurns: 5,\n    },\n  })\n\n  let review = \"\"\n  for await (const msg of result) {\n    if (msg.type === \"assistant\") review += msg.text\n  }\n  return review\n}\n","ts",[941,1180,1181,1195,1199,1227,1244,1260,1265,1275,1292,1302,1312,1317,1322,1326,1340,1363,1386,1391,1400],{"__ignoreMap":11},[1024,1182,1183,1186,1189,1192],{"class":1026,"line":1027},[1024,1184,1185],{"class":1056},"import",[1024,1187,1188],{"class":1030}," { query } ",[1024,1190,1191],{"class":1056},"from",[1024,1193,1194],{"class":1044}," \"@anthropic-ai\u002Fclaude-agent-sdk\"\n",[1024,1196,1197],{"class":1026,"line":1034},[1024,1198,1103],{"emptyLinePlaceholder":1102},[1024,1200,1201,1204,1207,1211,1214,1217,1220,1224],{"class":1026,"line":1048},[1024,1202,1203],{"class":1056},"async",[1024,1205,1206],{"class":1056}," function",[1024,1208,1210],{"class":1209},"snPdu"," codeReviewSubagent",[1024,1212,1213],{"class":1030},"(",[1024,1215,1216],{"class":1120},"file",[1024,1218,1219],{"class":1056},":",[1024,1221,1223],{"class":1222},"sBjJW"," string",[1024,1225,1226],{"class":1030},") {\n",[1024,1228,1229,1232,1235,1238,1241],{"class":1026,"line":1060},[1024,1230,1231],{"class":1056},"  const",[1024,1233,1234],{"class":1222}," result",[1024,1236,1237],{"class":1056}," =",[1024,1239,1240],{"class":1209}," query",[1024,1242,1243],{"class":1030},"({\n",[1024,1245,1246,1249,1252,1254,1257],{"class":1026,"line":1066},[1024,1247,1248],{"class":1030},"    prompt: ",[1024,1250,1251],{"class":1044},"`Review the file at ${",[1024,1253,1216],{"class":1030},[1024,1255,1256],{"class":1044},"}`",[1024,1258,1259],{"class":1030},",\n",[1024,1261,1262],{"class":1026,"line":1072},[1024,1263,1264],{"class":1030},"    options: {\n",[1024,1266,1267,1270,1273],{"class":1026,"line":1083},[1024,1268,1269],{"class":1030},"      systemPrompt: ",[1024,1271,1272],{"class":1044},"\"You are a senior code reviewer...\"",[1024,1274,1259],{"class":1030},[1024,1276,1277,1280,1283,1286,1289],{"class":1026,"line":1094},[1024,1278,1279],{"class":1030},"      allowedTools: [",[1024,1281,1282],{"class":1044},"\"Read\"",[1024,1284,1285],{"class":1030},", ",[1024,1287,1288],{"class":1044},"\"Grep\"",[1024,1290,1291],{"class":1030},"],\n",[1024,1293,1294,1297,1300],{"class":1026,"line":1099},[1024,1295,1296],{"class":1030},"      model: ",[1024,1298,1299],{"class":1044},"\"claude-sonnet-4-5\"",[1024,1301,1259],{"class":1030},[1024,1303,1304,1307,1310],{"class":1026,"line":1106},[1024,1305,1306],{"class":1030},"      maxTurns: ",[1024,1308,1309],{"class":1222},"5",[1024,1311,1259],{"class":1030},[1024,1313,1314],{"class":1026,"line":1112},[1024,1315,1316],{"class":1030},"    },\n",[1024,1318,1319],{"class":1026,"line":1117},[1024,1320,1321],{"class":1030},"  })\n",[1024,1323,1324],{"class":1026,"line":1127},[1024,1325,1103],{"emptyLinePlaceholder":1102},[1024,1327,1328,1331,1334,1337],{"class":1026,"line":1136},[1024,1329,1330],{"class":1056},"  let",[1024,1332,1333],{"class":1030}," review ",[1024,1335,1336],{"class":1056},"=",[1024,1338,1339],{"class":1044}," \"\"\n",[1024,1341,1342,1345,1348,1351,1354,1357,1360],{"class":1026,"line":1145},[1024,1343,1344],{"class":1056},"  for",[1024,1346,1347],{"class":1056}," await",[1024,1349,1350],{"class":1030}," (",[1024,1352,1353],{"class":1056},"const",[1024,1355,1356],{"class":1222}," msg",[1024,1358,1359],{"class":1056}," of",[1024,1361,1362],{"class":1030}," result) {\n",[1024,1364,1365,1368,1371,1374,1377,1380,1383],{"class":1026,"line":1154},[1024,1366,1367],{"class":1056},"    if",[1024,1369,1370],{"class":1030}," (msg.type ",[1024,1372,1373],{"class":1056},"===",[1024,1375,1376],{"class":1044}," \"assistant\"",[1024,1378,1379],{"class":1030},") review ",[1024,1381,1382],{"class":1056},"+=",[1024,1384,1385],{"class":1030}," msg.text\n",[1024,1387,1388],{"class":1026,"line":1159},[1024,1389,1390],{"class":1030},"  }\n",[1024,1392,1394,1397],{"class":1026,"line":1393},18,[1024,1395,1396],{"class":1056},"  return",[1024,1398,1399],{"class":1030}," review\n",[1024,1401,1403],{"class":1026,"line":1402},19,[1024,1404,1405],{"class":1030},"}\n",[897,1407,1408,1409,972],{},"本质上，subagent 就是",[900,1410,1411],{},"在主 Agent 的工具调用里启动另一个 Agent query",[892,1413,1414],{"id":1414},"通用调用协议",[897,1416,1417,1418,1420,1421,1424],{},"主 Agent 通常通过一个叫 ",[941,1419,1168],{},"（或 ",[941,1422,1423],{},"Task","）的内置工具调用子代理：",[933,1426,1430],{"className":1427,"code":1428,"language":1429,"meta":11,"style":11},"language-json shiki shiki-themes github-light github-light github-dark","{\n  \"tool\": \"Agent\",\n  \"input\": {\n    \"subagent_type\": \"code-reviewer\",\n    \"description\": \"Review auth module\",\n    \"prompt\": \"Review src\u002Fauth\u002F*.ts for security issues\"\n  }\n}\n","json",[941,1431,1432,1437,1449,1457,1469,1481,1491,1495],{"__ignoreMap":11},[1024,1433,1434],{"class":1026,"line":1027},[1024,1435,1436],{"class":1030},"{\n",[1024,1438,1439,1442,1444,1447],{"class":1026,"line":1034},[1024,1440,1441],{"class":1222},"  \"tool\"",[1024,1443,1041],{"class":1030},[1024,1445,1446],{"class":1044},"\"Agent\"",[1024,1448,1259],{"class":1030},[1024,1450,1451,1454],{"class":1026,"line":1048},[1024,1452,1453],{"class":1222},"  \"input\"",[1024,1455,1456],{"class":1030},": {\n",[1024,1458,1459,1462,1464,1467],{"class":1026,"line":1060},[1024,1460,1461],{"class":1222},"    \"subagent_type\"",[1024,1463,1041],{"class":1030},[1024,1465,1466],{"class":1044},"\"code-reviewer\"",[1024,1468,1259],{"class":1030},[1024,1470,1471,1474,1476,1479],{"class":1026,"line":1066},[1024,1472,1473],{"class":1222},"    \"description\"",[1024,1475,1041],{"class":1030},[1024,1477,1478],{"class":1044},"\"Review auth module\"",[1024,1480,1259],{"class":1030},[1024,1482,1483,1486,1488],{"class":1026,"line":1072},[1024,1484,1485],{"class":1222},"    \"prompt\"",[1024,1487,1041],{"class":1030},[1024,1489,1490],{"class":1044},"\"Review src\u002Fauth\u002F*.ts for security issues\"\n",[1024,1492,1493],{"class":1026,"line":1083},[1024,1494,1390],{"class":1030},[1024,1496,1497],{"class":1026,"line":1094},[1024,1498,1405],{"class":1030},[905,1500,1501,1507,1512],{},[908,1502,1503,1506],{},[941,1504,1505],{},"subagent_type","：指向配置文件中的 name",[908,1508,1509,1511],{},[941,1510,1051],{},"：简短说明（用于 UI \u002F 日志）",[908,1513,1514,1517],{},[941,1515,1516],{},"prompt","：完整任务描述",[897,1519,1520,1521,1524],{},"子代理执行完后，",[900,1522,1523],{},"只把最终文本结果","返回给主 Agent——中间过程不可见，避免污染上下文。",[892,1526,1527],{"id":1527},"并发模式",[948,1529,1531],{"id":1530},"顺序简单但慢","顺序（简单但慢）",[933,1533,1535],{"className":1176,"code":1534,"language":1178,"meta":11,"style":11},"const a = await subagent(\"task-a\")\nconst b = await subagent(\"task-b\")  \u002F\u002F 等 a 完成才开始\n",[941,1536,1537,1559],{"__ignoreMap":11},[1024,1538,1539,1541,1544,1546,1548,1551,1553,1556],{"class":1026,"line":1027},[1024,1540,1353],{"class":1056},[1024,1542,1543],{"class":1222}," a",[1024,1545,1237],{"class":1056},[1024,1547,1347],{"class":1056},[1024,1549,1550],{"class":1209}," subagent",[1024,1552,1213],{"class":1030},[1024,1554,1555],{"class":1044},"\"task-a\"",[1024,1557,1558],{"class":1030},")\n",[1024,1560,1561,1563,1566,1568,1570,1572,1574,1577,1580],{"class":1026,"line":1034},[1024,1562,1353],{"class":1056},[1024,1564,1565],{"class":1222}," b",[1024,1567,1237],{"class":1056},[1024,1569,1347],{"class":1056},[1024,1571,1550],{"class":1209},[1024,1573,1213],{"class":1030},[1024,1575,1576],{"class":1044},"\"task-b\"",[1024,1578,1579],{"class":1030},")  ",[1024,1581,1583],{"class":1582},"sCsY4","\u002F\u002F 等 a 完成才开始\n",[948,1585,1587],{"id":1586},"并行推荐","并行（推荐）",[933,1589,1591],{"className":1176,"code":1590,"language":1178,"meta":11,"style":11},"const [a, b, c] = await Promise.all([\n  subagent(\"task-a\"),\n  subagent(\"task-b\"),\n  subagent(\"task-c\"),\n])\n",[941,1592,1593,1632,1644,1654,1665],{"__ignoreMap":11},[1024,1594,1595,1597,1600,1603,1605,1608,1610,1613,1616,1618,1620,1623,1626,1629],{"class":1026,"line":1027},[1024,1596,1353],{"class":1056},[1024,1598,1599],{"class":1030}," [",[1024,1601,1602],{"class":1222},"a",[1024,1604,1285],{"class":1030},[1024,1606,1607],{"class":1222},"b",[1024,1609,1285],{"class":1030},[1024,1611,1612],{"class":1222},"c",[1024,1614,1615],{"class":1030},"] ",[1024,1617,1336],{"class":1056},[1024,1619,1347],{"class":1056},[1024,1621,1622],{"class":1222}," Promise",[1024,1624,1625],{"class":1030},".",[1024,1627,1628],{"class":1209},"all",[1024,1630,1631],{"class":1030},"([\n",[1024,1633,1634,1637,1639,1641],{"class":1026,"line":1034},[1024,1635,1636],{"class":1209},"  subagent",[1024,1638,1213],{"class":1030},[1024,1640,1555],{"class":1044},[1024,1642,1643],{"class":1030},"),\n",[1024,1645,1646,1648,1650,1652],{"class":1026,"line":1048},[1024,1647,1636],{"class":1209},[1024,1649,1213],{"class":1030},[1024,1651,1576],{"class":1044},[1024,1653,1643],{"class":1030},[1024,1655,1656,1658,1660,1663],{"class":1026,"line":1060},[1024,1657,1636],{"class":1209},[1024,1659,1213],{"class":1030},[1024,1661,1662],{"class":1044},"\"task-c\"",[1024,1664,1643],{"class":1030},[1024,1666,1667],{"class":1026,"line":1066},[1024,1668,1669],{"class":1030},"])\n",[897,1671,1672,1673,1676],{},"在主 Agent 的提示里，这种并发通常通过",[900,1674,1675],{},"一次性发出多个 Agent 工具调用","实现。SDK 和 harness 会自动并行执行。",[948,1678,1680],{"id":1679},"map-reduce-模式","Map-Reduce 模式",[933,1682,1685],{"className":1683,"code":1684,"language":938,"meta":939},[936],"flowchart LR\n    Split[\"主 Agent\u003Cbr\u002F>拆分任务\"]\n    Split --> A[\"Worker A\"]\n    Split --> B[\"Worker B\"]\n    Split --> C[\"Worker C\"]\n    A --> Reduce[\"主 Agent\u003Cbr\u002F>聚合结果\"]\n    B --> Reduce\n    C --> Reduce\n    Reduce --> Out[\"最终产出\"]\n",[941,1686,1684],{"__ignoreMap":11},[897,1688,1689],{},"例子：\"分析 git log 过去 1 年\"：",[1691,1692,1693,1696,1699],"ol",{},[908,1694,1695],{},"主 Agent 把 12 个月拆成 12 个 subagent",[908,1697,1698],{},"每个 subagent 独立分析一个月",[908,1700,1701],{},"主 Agent 把 12 份报告合并",[897,1703,1704,1705,972],{},"上下文从 \"12 个月的 commits\" 变成 \"12 份 1 页的摘要\"——",[900,1706,1707],{},"从 O(N) 变成 O(1)",[892,1709,1711],{"id":1710},"典型-subagent-类型","典型 Subagent 类型",[897,1713,1714],{},"下面是一些值得沉淀的通用 subagent：",[1716,1717,1718,1734],"table",{},[1719,1720,1721],"thead",{},[1722,1723,1724,1728,1731],"tr",{},[1725,1726,1727],"th",{},"类型",[1725,1729,1730],{},"用途",[1725,1732,1733],{},"关键配置",[1735,1736,1737,1751,1764,1777,1790,1803,1816],"tbody",{},[1722,1738,1739,1745,1748],{},[1740,1741,1742],"td",{},[900,1743,1744],{},"research",[1740,1746,1747],{},"调研信息后给总结",[1740,1749,1750],{},"开放 WebFetch\u002FSearch，low temp",[1722,1752,1753,1758,1761],{},[1740,1754,1755],{},[900,1756,1757],{},"code-reviewer",[1740,1759,1760],{},"代码审查",[1740,1762,1763],{},"只给 Read\u002FGrep，严格 prompt",[1722,1765,1766,1771,1774],{},[1740,1767,1768],{},[900,1769,1770],{},"refactor",[1740,1772,1773],{},"重构代码",[1740,1775,1776],{},"给 Edit，要求保留测试通过",[1722,1778,1779,1784,1787],{},[1740,1780,1781],{},[900,1782,1783],{},"test-runner",[1740,1785,1786],{},"跑测试并分析失败",[1740,1788,1789],{},"Bash + Read",[1722,1791,1792,1797,1800],{},[1740,1793,1794],{},[900,1795,1796],{},"doc-writer",[1740,1798,1799],{},"生成文档",[1740,1801,1802],{},"创意风格，高 temp",[1722,1804,1805,1810,1813],{},[1740,1806,1807],{},[900,1808,1809],{},"planner",[1740,1811,1812],{},"分解任务",[1740,1814,1815],{},"不给执行工具，只输出 plan",[1722,1817,1818,1823,1826],{},[1740,1819,1820],{},[900,1821,1822],{},"validator",[1740,1824,1825],{},"验证产物",[1740,1827,1828],{},"Read only，严格判定",[892,1830,1832],{"id":1831},"何时该拆-subagent","何时该拆 Subagent",[948,1834,1835],{"id":1835},"拆分的信号",[897,1837,1838],{},"✅ 考虑拆分的场景：",[905,1840,1841,1844,1850,1856,1862],{},[908,1842,1843],{},"预计要读取 > 10 个文件",[908,1845,1846,1847],{},"子任务需要与主任务",[900,1848,1849],{},"不同的工具集",[908,1851,1852,1853],{},"子任务可以",[900,1854,1855],{},"并行",[908,1857,1858,1859],{},"子任务产出的",[900,1860,1861],{},"中间过程主线不需要",[908,1863,1864,1865,1868],{},"需要",[900,1866,1867],{},"隔离故障","（某一步失败不影响其他）",[948,1870,1871],{"id":1871},"不拆分的信号",[897,1873,1874],{},"❌ 不应拆分：",[905,1876,1877,1880,1883,1886],{},[908,1878,1879],{},"子任务需要高频访问主 Agent 的上下文",[908,1881,1882],{},"任务规模小（串行更简单）",[908,1884,1885],{},"需要多轮交互才能完成",[908,1887,1888],{},"中间状态对主线非常重要",[897,1890,1891,1892,972],{},"经验法则：",[900,1893,1894],{},"如果\"只需要一个最终答案\"，就适合拆；如果\"需要跟进过程\"，就不拆",[892,1896,1897],{"id":1897},"传递上下文的技巧",[897,1899,1900],{},"子代理没有父代理的历史，怎么传上下文？",[948,1902,1904],{"id":1903},"技巧-1在-prompt-里显式传","技巧 1：在 prompt 里显式传",[933,1906,1908],{"className":1176,"code":1907,"language":1178,"meta":11,"style":11},"const prompt = `\n上下文：用户正在开发一个 React 项目，使用 TypeScript + Vite。\n当前目录：${cwd}\n相关文件：${files.join(', ')}\n\n任务：${actualTask}\n`\n",[941,1909,1910,1922,1927,1937,1960,1964,1974],{"__ignoreMap":11},[1024,1911,1912,1914,1917,1919],{"class":1026,"line":1027},[1024,1913,1353],{"class":1056},[1024,1915,1916],{"class":1222}," prompt",[1024,1918,1237],{"class":1056},[1024,1920,1921],{"class":1044}," `\n",[1024,1923,1924],{"class":1026,"line":1034},[1024,1925,1926],{"class":1044},"上下文：用户正在开发一个 React 项目，使用 TypeScript + Vite。\n",[1024,1928,1929,1932,1935],{"class":1026,"line":1048},[1024,1930,1931],{"class":1044},"当前目录：${",[1024,1933,1934],{"class":1030},"cwd",[1024,1936,1405],{"class":1044},[1024,1938,1939,1942,1945,1947,1950,1952,1955,1958],{"class":1026,"line":1060},[1024,1940,1941],{"class":1044},"相关文件：${",[1024,1943,1944],{"class":1030},"files",[1024,1946,1625],{"class":1044},[1024,1948,1949],{"class":1209},"join",[1024,1951,1213],{"class":1044},[1024,1953,1954],{"class":1044},"', '",[1024,1956,1957],{"class":1044},")",[1024,1959,1405],{"class":1044},[1024,1961,1962],{"class":1026,"line":1066},[1024,1963,1103],{"emptyLinePlaceholder":1102},[1024,1965,1966,1969,1972],{"class":1026,"line":1072},[1024,1967,1968],{"class":1044},"任务：${",[1024,1970,1971],{"class":1030},"actualTask",[1024,1973,1405],{"class":1044},[1024,1975,1976],{"class":1026,"line":1083},[1024,1977,1978],{"class":1044},"`\n",[948,1980,1982],{"id":1981},"技巧-2通过工作目录-文件共享","技巧 2：通过工作目录 \u002F 文件共享",[897,1984,1985],{},"子代理与父代理共享文件系统。主 Agent 把要共享的信息写入文件，子代理用 Read 读：",[933,1987,1989],{"className":1176,"code":1988,"language":1178,"meta":11,"style":11},"await writeFile(\".claude\u002Fctx\u002Fcurrent.json\", JSON.stringify(context))\n\u002F\u002F 子代理 prompt：\"首先读取 .claude\u002Fctx\u002Fcurrent.json 了解上下文\"\n",[941,1990,1991,2017],{"__ignoreMap":11},[1024,1992,1993,1996,1999,2001,2004,2006,2009,2011,2014],{"class":1026,"line":1027},[1024,1994,1995],{"class":1056},"await",[1024,1997,1998],{"class":1209}," writeFile",[1024,2000,1213],{"class":1030},[1024,2002,2003],{"class":1044},"\".claude\u002Fctx\u002Fcurrent.json\"",[1024,2005,1285],{"class":1030},[1024,2007,2008],{"class":1222},"JSON",[1024,2010,1625],{"class":1030},[1024,2012,2013],{"class":1209},"stringify",[1024,2015,2016],{"class":1030},"(context))\n",[1024,2018,2019],{"class":1026,"line":1034},[1024,2020,2021],{"class":1582},"\u002F\u002F 子代理 prompt：\"首先读取 .claude\u002Fctx\u002Fcurrent.json 了解上下文\"\n",[948,2023,2025],{"id":2024},"技巧-3通过-mcp-资源","技巧 3：通过 MCP 资源",[897,2027,2028],{},"让主代理和子代理共用同一组 MCP servers，状态通过 MCP 的 Resources 共享。",[892,2030,2031],{"id":2031},"避坑指南",[948,2033,2035],{"id":2034},"坑-1嵌套过深","坑 1：嵌套过深",[897,2037,2038],{},"subagent 调用 subagent 调用 subagent 很快就失控。经验：",[905,2040,2041,2044],{},[908,2042,2043],{},"最多 2 层嵌套",[908,2045,2046],{},"超过 2 层通常说明任务拆分方式不对",[948,2048,2050],{"id":2049},"坑-2期望子代理反馈进度","坑 2：期望子代理\"反馈进度\"",[897,2052,2053,2054,2057],{},"子代理只返回",[900,2055,2056],{},"最终结果","。想看过程就不该拆。",[948,2059,2061],{"id":2060},"坑-3子代理越权","坑 3：子代理越权",[897,2063,2064,2065,2068],{},"子代理默认继承主代理的部分能力。务必用 ",[941,2066,2067],{},"allowedTools"," 限制它能做什么，尤其是\"只读\"任务不要给 Write\u002FBash。",[948,2070,2072],{"id":2071},"坑-4并发冲突","坑 4：并发冲突",[897,2074,2075,2076,2079,2080,972],{},"多个子代理同时写同一个文件会出竞争。并发任务之间必须是",[900,2077,2078],{},"读-读","或",[900,2081,2082],{},"写-不同目标",[948,2084,2086],{"id":2085},"坑-5上下文过载传递","坑 5：上下文过载传递",[933,2088,2090],{"className":1176,"code":2089,"language":1178,"meta":11,"style":11},"\u002F\u002F ❌ 把主代理半个对话历史塞进 prompt\nconst prompt = `上下文：${JSON.stringify(allHistory)}...`\n\n\u002F\u002F ✅ 只传必要信息\nconst prompt = `任务：${task}\\n已知关键信息：${summary}`\n",[941,2091,2092,2097,2124,2128,2133],{"__ignoreMap":11},[1024,2093,2094],{"class":1026,"line":1027},[1024,2095,2096],{"class":1582},"\u002F\u002F ❌ 把主代理半个对话历史塞进 prompt\n",[1024,2098,2099,2101,2103,2105,2108,2110,2112,2114,2116,2119,2121],{"class":1026,"line":1034},[1024,2100,1353],{"class":1056},[1024,2102,1916],{"class":1222},[1024,2104,1237],{"class":1056},[1024,2106,2107],{"class":1044}," `上下文：${",[1024,2109,2008],{"class":1222},[1024,2111,1625],{"class":1044},[1024,2113,2013],{"class":1209},[1024,2115,1213],{"class":1044},[1024,2117,2118],{"class":1030},"allHistory",[1024,2120,1957],{"class":1044},[1024,2122,2123],{"class":1044},"}...`\n",[1024,2125,2126],{"class":1026,"line":1048},[1024,2127,1103],{"emptyLinePlaceholder":1102},[1024,2129,2130],{"class":1026,"line":1060},[1024,2131,2132],{"class":1582},"\u002F\u002F ✅ 只传必要信息\n",[1024,2134,2135,2137,2139,2141,2144,2147,2150,2153,2156,2159],{"class":1026,"line":1066},[1024,2136,1353],{"class":1056},[1024,2138,1916],{"class":1222},[1024,2140,1237],{"class":1056},[1024,2142,2143],{"class":1044}," `任务：${",[1024,2145,2146],{"class":1030},"task",[1024,2148,2149],{"class":1044},"}",[1024,2151,2152],{"class":1222},"\\n",[1024,2154,2155],{"class":1044},"已知关键信息：${",[1024,2157,2158],{"class":1030},"summary",[1024,2160,2161],{"class":1044},"}`\n",[892,2163,2164],{"id":2164},"监控与调试",[948,2166,2168],{"id":2167},"日志每个-subagent","日志每个 subagent",[897,2170,2171],{},"给每次调用打 trace id：",[933,2173,2175],{"className":1176,"code":2174,"language":1178,"meta":11,"style":11},"const traceId = crypto.randomUUID()\nconsole.log(`[${traceId}] subagent start: ${name}`)\nconst result = await runSubagent(name, prompt)\nconsole.log(`[${traceId}] subagent done: ${result.length} chars`)\n",[941,2176,2177,2195,2219,2235],{"__ignoreMap":11},[1024,2178,2179,2181,2184,2186,2189,2192],{"class":1026,"line":1027},[1024,2180,1353],{"class":1056},[1024,2182,2183],{"class":1222}," traceId",[1024,2185,1237],{"class":1056},[1024,2187,2188],{"class":1030}," crypto.",[1024,2190,2191],{"class":1209},"randomUUID",[1024,2193,2194],{"class":1030},"()\n",[1024,2196,2197,2200,2202,2204,2207,2210,2213,2215,2217],{"class":1026,"line":1034},[1024,2198,2199],{"class":1030},"console.",[1024,2201,260],{"class":1209},[1024,2203,1213],{"class":1030},[1024,2205,2206],{"class":1044},"`[${",[1024,2208,2209],{"class":1030},"traceId",[1024,2211,2212],{"class":1044},"}] subagent start: ${",[1024,2214,1038],{"class":1030},[1024,2216,1256],{"class":1044},[1024,2218,1558],{"class":1030},[1024,2220,2221,2223,2225,2227,2229,2232],{"class":1026,"line":1048},[1024,2222,1353],{"class":1056},[1024,2224,1234],{"class":1222},[1024,2226,1237],{"class":1056},[1024,2228,1347],{"class":1056},[1024,2230,2231],{"class":1209}," runSubagent",[1024,2233,2234],{"class":1030},"(name, prompt)\n",[1024,2236,2237,2239,2241,2243,2245,2247,2250,2253,2255,2258,2261],{"class":1026,"line":1060},[1024,2238,2199],{"class":1030},[1024,2240,260],{"class":1209},[1024,2242,1213],{"class":1030},[1024,2244,2206],{"class":1044},[1024,2246,2209],{"class":1030},[1024,2248,2249],{"class":1044},"}] subagent done: ${",[1024,2251,2252],{"class":1030},"result",[1024,2254,1625],{"class":1044},[1024,2256,2257],{"class":1222},"length",[1024,2259,2260],{"class":1044},"} chars`",[1024,2262,1558],{"class":1030},[948,2264,2266],{"id":2265},"配合-subagentstop-hook","配合 SubagentStop Hook",[897,2268,2269],{},"利用 Hooks 在 subagent 结束时自动记录：",[933,2271,2273],{"className":1427,"code":2272,"language":1429,"meta":11,"style":11},"{\n  \"hooks\": {\n    \"SubagentStop\": [{\n      \"hooks\": [{ \"type\": \"command\", \"command\": \"bash .claude\u002Fhooks\u002Flog-sub.sh\" }]\n    }]\n  }\n}\n",[941,2274,2275,2279,2286,2294,2322,2327,2331],{"__ignoreMap":11},[1024,2276,2277],{"class":1026,"line":1027},[1024,2278,1436],{"class":1030},[1024,2280,2281,2284],{"class":1026,"line":1034},[1024,2282,2283],{"class":1222},"  \"hooks\"",[1024,2285,1456],{"class":1030},[1024,2287,2288,2291],{"class":1026,"line":1048},[1024,2289,2290],{"class":1222},"    \"SubagentStop\"",[1024,2292,2293],{"class":1030},": [{\n",[1024,2295,2296,2299,2302,2305,2307,2310,2312,2314,2316,2319],{"class":1026,"line":1060},[1024,2297,2298],{"class":1222},"      \"hooks\"",[1024,2300,2301],{"class":1030},": [{ ",[1024,2303,2304],{"class":1222},"\"type\"",[1024,2306,1041],{"class":1030},[1024,2308,2309],{"class":1044},"\"command\"",[1024,2311,1285],{"class":1030},[1024,2313,2309],{"class":1222},[1024,2315,1041],{"class":1030},[1024,2317,2318],{"class":1044},"\"bash .claude\u002Fhooks\u002Flog-sub.sh\"",[1024,2320,2321],{"class":1030}," }]\n",[1024,2323,2324],{"class":1026,"line":1066},[1024,2325,2326],{"class":1030},"    }]\n",[1024,2328,2329],{"class":1026,"line":1072},[1024,2330,1390],{"class":1030},[1024,2332,2333],{"class":1026,"line":1083},[1024,2334,1405],{"class":1030},[948,2336,2337],{"id":2337},"可观测指标",[897,2339,2340],{},"值得监控：",[905,2342,2343,2346,2349,2352],{},[908,2344,2345],{},"每个 subagent 的 token 消耗",[908,2347,2348],{},"每个 subagent 的耗时",[908,2350,2351],{},"成功率 \u002F 超时率",[908,2353,2354],{},"调用层级分布",[892,2356,2358],{"id":2357},"实战案例代码仓库分析-agent","实战案例：代码仓库分析 Agent",[897,2360,2361],{},"任务：分析一个仓库，产出架构总结、依赖图、风险清单。",[933,2363,2365],{"className":1176,"code":2364,"language":1178,"meta":11,"style":11},"\u002F\u002F 1. 主 Agent 分析仓库结构\nconst files = await query({\n  prompt: \"列出仓库中所有关键源码目录\",\n  options: { allowedTools: [\"Glob\", \"Read\"] },\n})\n\n\u002F\u002F 2. 对每个模块并行启动子代理\nconst analyses = await Promise.all(\n  modules.map(m =>\n    runSubagent(\"module-analyzer\", `分析模块 ${m}：职责、依赖、风险`)\n  )\n)\n\n\u002F\u002F 3. 安全审计子代理（独立上下文）\nconst security = await runSubagent(\n  \"security-auditor\",\n  \"扫描整个仓库的安全问题\"\n)\n\n\u002F\u002F 4. 依赖图子代理\nconst depGraph = await runSubagent(\n  \"dep-graph-builder\",\n  \"产出模块依赖 mermaid 图\"\n)\n\n\u002F\u002F 5. 主 Agent 汇总\nconst finalReport = await query({\n  prompt: `基于以下材料产出架构报告：\n  模块分析：${analyses.join(\"\\n\")}\n  安全审计：${security}\n  依赖图：${depGraph}`,\n})\n",[941,2366,2367,2372,2387,2397,2412,2417,2421,2426,2446,2462,2484,2489,2493,2497,2502,2517,2524,2529,2533,2537,2543,2559,2567,2573,2578,2583,2589,2605,2613,2639,2650,2663],{"__ignoreMap":11},[1024,2368,2369],{"class":1026,"line":1027},[1024,2370,2371],{"class":1582},"\u002F\u002F 1. 主 Agent 分析仓库结构\n",[1024,2373,2374,2376,2379,2381,2383,2385],{"class":1026,"line":1034},[1024,2375,1353],{"class":1056},[1024,2377,2378],{"class":1222}," files",[1024,2380,1237],{"class":1056},[1024,2382,1347],{"class":1056},[1024,2384,1240],{"class":1209},[1024,2386,1243],{"class":1030},[1024,2388,2389,2392,2395],{"class":1026,"line":1048},[1024,2390,2391],{"class":1030},"  prompt: ",[1024,2393,2394],{"class":1044},"\"列出仓库中所有关键源码目录\"",[1024,2396,1259],{"class":1030},[1024,2398,2399,2402,2405,2407,2409],{"class":1026,"line":1060},[1024,2400,2401],{"class":1030},"  options: { allowedTools: [",[1024,2403,2404],{"class":1044},"\"Glob\"",[1024,2406,1285],{"class":1030},[1024,2408,1282],{"class":1044},[1024,2410,2411],{"class":1030},"] },\n",[1024,2413,2414],{"class":1026,"line":1066},[1024,2415,2416],{"class":1030},"})\n",[1024,2418,2419],{"class":1026,"line":1072},[1024,2420,1103],{"emptyLinePlaceholder":1102},[1024,2422,2423],{"class":1026,"line":1083},[1024,2424,2425],{"class":1582},"\u002F\u002F 2. 对每个模块并行启动子代理\n",[1024,2427,2428,2430,2433,2435,2437,2439,2441,2443],{"class":1026,"line":1094},[1024,2429,1353],{"class":1056},[1024,2431,2432],{"class":1222}," analyses",[1024,2434,1237],{"class":1056},[1024,2436,1347],{"class":1056},[1024,2438,1622],{"class":1222},[1024,2440,1625],{"class":1030},[1024,2442,1628],{"class":1209},[1024,2444,2445],{"class":1030},"(\n",[1024,2447,2448,2451,2454,2456,2459],{"class":1026,"line":1099},[1024,2449,2450],{"class":1030},"  modules.",[1024,2452,2453],{"class":1209},"map",[1024,2455,1213],{"class":1030},[1024,2457,2458],{"class":1120},"m",[1024,2460,2461],{"class":1056}," =>\n",[1024,2463,2464,2467,2469,2472,2474,2477,2479,2482],{"class":1026,"line":1106},[1024,2465,2466],{"class":1209},"    runSubagent",[1024,2468,1213],{"class":1030},[1024,2470,2471],{"class":1044},"\"module-analyzer\"",[1024,2473,1285],{"class":1030},[1024,2475,2476],{"class":1044},"`分析模块 ${",[1024,2478,2458],{"class":1030},[1024,2480,2481],{"class":1044},"}：职责、依赖、风险`",[1024,2483,1558],{"class":1030},[1024,2485,2486],{"class":1026,"line":1112},[1024,2487,2488],{"class":1030},"  )\n",[1024,2490,2491],{"class":1026,"line":1117},[1024,2492,1558],{"class":1030},[1024,2494,2495],{"class":1026,"line":1127},[1024,2496,1103],{"emptyLinePlaceholder":1102},[1024,2498,2499],{"class":1026,"line":1136},[1024,2500,2501],{"class":1582},"\u002F\u002F 3. 安全审计子代理（独立上下文）\n",[1024,2503,2504,2506,2509,2511,2513,2515],{"class":1026,"line":1145},[1024,2505,1353],{"class":1056},[1024,2507,2508],{"class":1222}," security",[1024,2510,1237],{"class":1056},[1024,2512,1347],{"class":1056},[1024,2514,2231],{"class":1209},[1024,2516,2445],{"class":1030},[1024,2518,2519,2522],{"class":1026,"line":1154},[1024,2520,2521],{"class":1044},"  \"security-auditor\"",[1024,2523,1259],{"class":1030},[1024,2525,2526],{"class":1026,"line":1159},[1024,2527,2528],{"class":1044},"  \"扫描整个仓库的安全问题\"\n",[1024,2530,2531],{"class":1026,"line":1393},[1024,2532,1558],{"class":1030},[1024,2534,2535],{"class":1026,"line":1402},[1024,2536,1103],{"emptyLinePlaceholder":1102},[1024,2538,2540],{"class":1026,"line":2539},20,[1024,2541,2542],{"class":1582},"\u002F\u002F 4. 依赖图子代理\n",[1024,2544,2546,2548,2551,2553,2555,2557],{"class":1026,"line":2545},21,[1024,2547,1353],{"class":1056},[1024,2549,2550],{"class":1222}," depGraph",[1024,2552,1237],{"class":1056},[1024,2554,1347],{"class":1056},[1024,2556,2231],{"class":1209},[1024,2558,2445],{"class":1030},[1024,2560,2562,2565],{"class":1026,"line":2561},22,[1024,2563,2564],{"class":1044},"  \"dep-graph-builder\"",[1024,2566,1259],{"class":1030},[1024,2568,2570],{"class":1026,"line":2569},23,[1024,2571,2572],{"class":1044},"  \"产出模块依赖 mermaid 图\"\n",[1024,2574,2576],{"class":1026,"line":2575},24,[1024,2577,1558],{"class":1030},[1024,2579,2581],{"class":1026,"line":2580},25,[1024,2582,1103],{"emptyLinePlaceholder":1102},[1024,2584,2586],{"class":1026,"line":2585},26,[1024,2587,2588],{"class":1582},"\u002F\u002F 5. 主 Agent 汇总\n",[1024,2590,2592,2594,2597,2599,2601,2603],{"class":1026,"line":2591},27,[1024,2593,1353],{"class":1056},[1024,2595,2596],{"class":1222}," finalReport",[1024,2598,1237],{"class":1056},[1024,2600,1347],{"class":1056},[1024,2602,1240],{"class":1209},[1024,2604,1243],{"class":1030},[1024,2606,2608,2610],{"class":1026,"line":2607},28,[1024,2609,2391],{"class":1030},[1024,2611,2612],{"class":1044},"`基于以下材料产出架构报告：\n",[1024,2614,2616,2619,2622,2624,2626,2628,2631,2633,2635,2637],{"class":1026,"line":2615},29,[1024,2617,2618],{"class":1044},"  模块分析：${",[1024,2620,2621],{"class":1030},"analyses",[1024,2623,1625],{"class":1044},[1024,2625,1949],{"class":1209},[1024,2627,1213],{"class":1044},[1024,2629,2630],{"class":1044},"\"",[1024,2632,2152],{"class":1222},[1024,2634,2630],{"class":1044},[1024,2636,1957],{"class":1044},[1024,2638,1405],{"class":1044},[1024,2640,2642,2645,2648],{"class":1026,"line":2641},30,[1024,2643,2644],{"class":1044},"  安全审计：${",[1024,2646,2647],{"class":1030},"security",[1024,2649,1405],{"class":1044},[1024,2651,2653,2656,2659,2661],{"class":1026,"line":2652},31,[1024,2654,2655],{"class":1044},"  依赖图：${",[1024,2657,2658],{"class":1030},"depGraph",[1024,2660,1256],{"class":1044},[1024,2662,1259],{"class":1030},[1024,2664,2666],{"class":1026,"line":2665},32,[1024,2667,2416],{"class":1030},[897,2669,2670],{},"关键点：",[905,2672,2673,2680,2683],{},[908,2674,2675,2676,2679],{},"并行 ",[941,2677,2678],{},"Promise.all"," 把总时间压缩",[908,2681,2682],{},"每个子代理配置不同 system prompt",[908,2684,2685],{},"主 Agent 只看\"摘要\"，上下文很小",[892,2687,2688],{"id":2688},"小结",[897,2690,2691],{},"Subagents 是 Agent 架构的\"分治法\"：",[905,2693,2694,2699,2705,2711],{},[908,2695,2696,2698],{},[900,2697,912],{},"防止爆炸",[908,2700,2701,2704],{},[900,2702,2703],{},"并发","压缩时间",[908,2706,2707,2710],{},[900,2708,2709],{},"专业化","提升质量",[908,2712,2713,2716],{},[900,2714,2715],{},"隔离","提升稳健",[897,2718,2719],{},"记住三条：",[1691,2721,2722,2727,2732],{},[908,2723,2724],{},[900,2725,2726],{},"只传必要信息，只取最终结果",[908,2728,2729],{},[900,2730,2731],{},"严格限制子代理工具集",[908,2733,2734],{},[900,2735,2736],{},"不超过 2 层嵌套",[897,2738,2739,2740,2743,2744,2743,2747,2743,2750,2753],{},"配合前面介绍的 ",[1602,2741,2742],{"href":29},"Agent SDK","、",[1602,2745,2746],{"href":17},"Hooks",[1602,2748,2749],{"href":129},"Skills",[1602,2751,2752],{"href":81},"MCP","，你就拥有了构建复杂 Agent 系统的全套能力。",[2755,2756,2757],"style",{},"html pre.shiki code .s8jYJ, html code.shiki .s8jYJ{--shiki-light:#D73A49;--shiki-default:#D73A49;--shiki-dark:#F97583}html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}html pre.shiki code .sIIMD, html code.shiki .sIIMD{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#9ECBFF}html pre.shiki code .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}html pre.shiki code .sP4rz, html code.shiki .sP4rz{--shiki-light:#E36209;--shiki-default:#E36209;--shiki-dark:#FFAB70}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .sovSZ, html code.shiki .sovSZ{--shiki-light:#22863A;--shiki-default:#22863A;--shiki-dark:#85E89D}",{"title":11,"searchDepth":1034,"depth":1034,"links":2759},[2760,2761,2766,2770,2771,2776,2777,2781,2786,2793,2798,2799],{"id":894,"depth":1034,"text":895},{"id":945,"depth":1034,"text":946,"children":2762},[2763,2764,2765],{"id":950,"depth":1048,"text":951},{"id":975,"depth":1048,"text":976},{"id":982,"depth":1048,"text":983},{"id":1000,"depth":1034,"text":1001,"children":2767},[2768,2769],{"id":1007,"depth":1048,"text":1008},{"id":1172,"depth":1048,"text":1173},{"id":1414,"depth":1034,"text":1414},{"id":1527,"depth":1034,"text":1527,"children":2772},[2773,2774,2775],{"id":1530,"depth":1048,"text":1531},{"id":1586,"depth":1048,"text":1587},{"id":1679,"depth":1048,"text":1680},{"id":1710,"depth":1034,"text":1711},{"id":1831,"depth":1034,"text":1832,"children":2778},[2779,2780],{"id":1835,"depth":1048,"text":1835},{"id":1871,"depth":1048,"text":1871},{"id":1897,"depth":1034,"text":1897,"children":2782},[2783,2784,2785],{"id":1903,"depth":1048,"text":1904},{"id":1981,"depth":1048,"text":1982},{"id":2024,"depth":1048,"text":2025},{"id":2031,"depth":1034,"text":2031,"children":2787},[2788,2789,2790,2791,2792],{"id":2034,"depth":1048,"text":2035},{"id":2049,"depth":1048,"text":2050},{"id":2060,"depth":1048,"text":2061},{"id":2071,"depth":1048,"text":2072},{"id":2085,"depth":1048,"text":2086},{"id":2164,"depth":1034,"text":2164,"children":2794},[2795,2796,2797],{"id":2167,"depth":1048,"text":2168},{"id":2265,"depth":1048,"text":2266},{"id":2337,"depth":1048,"text":2337},{"id":2357,"depth":1034,"text":2358},{"id":2688,"depth":1034,"text":2688},"md",{},{"title":34,"description":35},"ai\u002Fagent\u002Fsubagents","-uuAY3s9QhKtBpoKvJJUx4ITxUW_K1U1XY6VbWR60nY",1775474635898]