Subagentes funcionam dentro de uma única sessão. Para executar muitas sessões independentes em paralelo e monitorá-las de um único lugar, consulte agentes em segundo plano. Para sessões que se comunicam entre si, consulte equipes de agentes.
- Preservar contexto mantendo exploração e implementação fora de sua conversa principal
- Aplicar restrições limitando quais ferramentas um subagente pode usar
- Reutilizar configurações entre projetos com subagentes no nível do usuário
- Especializar comportamento com prompts de sistema focados para domínios específicos
- Controlar custos roteando tarefas para modelos mais rápidos e baratos como Haiku
Subagentes integrados
Claude Code inclui subagentes integrados que Claude usa automaticamente quando apropriado. Cada um herda as permissões da conversa pai com restrições de ferramentas adicionais. Explore e Plan pulam seus arquivos CLAUDE.md e o status git da sessão pai para manter a pesquisa rápida e econômica. Todos os outros subagentes integrados e subagentes personalizados carregam ambos. Para o detalhamento completo do que chega a um subagente, consulte o que é carregado na inicialização.- Explore
- Plan
- General-purpose
- Other
Um agente rápido e somente leitura otimizado para pesquisar e analisar bases de código.
- Model: Haiku, que é rápido e de baixa latência
- Tools: ferramentas somente leitura; Write e Edit são negados
- Purpose: descoberta de arquivos, pesquisa de código, exploração de base de código
- Para bloquear um tipo integrado específico, adicione-o a
permissions.denyconforme mostrado em Desabilitar subagentes específicos. - Para impedir que Claude delegue a qualquer subagente, negue a ferramenta
Agentem si compermissions.deny. - Em modo não interativo e no Agent SDK, defina
CLAUDE_AGENT_SDK_DISABLE_BUILTIN_AGENTS=1para remover todos os tipos integrados e fornecer apenas os seus próprios.
Quickstart: criar seu primeiro subagente
Subagentes são definidos em arquivos Markdown com frontmatter YAML. Você pode criá-los manualmente ou usar o comando/agents.
Este passo a passo o guia através da criação de um subagente no nível do usuário com o comando /agents. O subagente revisa código e sugere melhorias para a base de código.
Escolher um local
Mude para a aba Library, selecione Create new agent, depois escolha Personal. Isso salva o subagente em
~/.claude/agents/ para que esteja disponível em todos os seus projetos.Gerar com Claude
Selecione Generate with Claude. Quando solicitado, descreva o subagente:Claude gera o identificador, descrição e prompt de sistema para você.
Selecionar ferramentas
Para um revisor somente leitura, desselecione tudo exceto Read-only tools. Se você manter todas as ferramentas selecionadas, o subagente herda todas as ferramentas disponíveis para a conversa principal.
Selecionar modelo
Escolha qual modelo o subagente usa. Para este agente de exemplo, selecione Sonnet, que equilibra capacidade e velocidade para analisar padrões de código.
Escolher uma cor
Escolha uma cor de fundo para o subagente. Isso ajuda você a identificar qual subagente está sendo executado na interface do usuário.
Configurar memória
Selecione User scope para dar ao subagente um diretório de memória persistente em
~/.claude/agent-memory/. O subagente usa isso para acumular insights entre conversas, como padrões de base de código e problemas recorrentes. Selecione None se você não quiser que o subagente persista aprendizados.Configurar subagentes
Usar o comando /agents
O comando/agents abre uma interface com abas para gerenciar subagentes. A aba Running lista subagentes ao vivo e recentemente finalizados e permite que você os abra ou pare. A aba Library permite que você:
- Visualize todos os subagentes disponíveis (integrados, usuário, projeto e plugin)
- Crie novos subagentes com configuração guiada ou geração por Claude
- Edite configuração de subagente existente e acesso a ferramentas
- Delete subagentes personalizados
- Veja quais subagentes estão ativos quando duplicatas existem
Escolher o escopo do subagente
Subagentes são arquivos Markdown com frontmatter YAML. Armazene-os em locais diferentes dependendo do escopo. Quando múltiplos subagentes compartilham o mesmo nome, Claude Code usa o que está no local de prioridade mais alta.| Location | Scope | Priority | How to create |
|---|---|---|---|
| Managed settings | Organization-wide | 1 (highest) | Deployed via managed settings |
--agents CLI flag | Current session | 2 | Pass JSON when launching Claude Code |
.claude/agents/ | Current project | 3 | Interactive or manual |
~/.claude/agents/ | All your projects | 4 | Interactive or manual |
Plugin’s agents/ directory | Where plugin is enabled | 5 (lowest) | Installed with plugins |
.claude/agents/) são ideais para subagentes específicos de uma base de código. Verifique-os no controle de versão para que sua equipe possa usá-los e melhorá-los colaborativamente.
Subagentes de projeto são descobertos caminhando para cima a partir do diretório de trabalho atual, portanto cada .claude/agents/ entre lá e a raiz do repositório é verificado. A partir da v2.1.178, quando mais de um desses diretórios aninhados define o mesmo name, Claude Code usa a definição mais próxima do diretório de trabalho.
Diretórios adicionados com --add-dir também são verificados: uma pasta .claude/agents/ dentro de um diretório adicionado carrega junto com subagentes de projeto. Veja Diretórios adicionais para quais outros tipos de configuração carregam de --add-dir. Para compartilhar subagentes entre projetos sem --add-dir, use ~/.claude/agents/ ou um plugin.
Subagentes de usuário (~/.claude/agents/) são subagentes pessoais disponíveis em todos os seus projetos.
Claude Code verifica .claude/agents/ e ~/.claude/agents/ recursivamente, para que você possa organizar definições em subpastas como agents/review/ ou agents/research/. O caminho do subdiretório não afeta como um subagente é identificado ou invocado, porque a identidade vem apenas do campo name do frontmatter.
Mantenha valores de name únicos em toda a árvore: se dois arquivos dentro de um escopo declaram o mesmo nome, Claude Code carrega apenas um deles. A partir da v2.1.196, executar /doctor relata nomes de agentes duplicados no mesmo escopo e mostra qual definição está ativa.
Diretórios agents/ de plugin também são verificados recursivamente. Diferentemente dos escopos de projeto e usuário, uma subpasta dentro do diretório agents/ de um plugin se torna parte do identificador com escopo: um arquivo em agents/review/security.md no plugin my-plugin se registra como my-plugin:review:security.
Subagentes definidos por CLI são passados como JSON ao iniciar Claude Code. Eles existem apenas para essa sessão e não são salvos em disco, tornando-os úteis para testes rápidos ou scripts de automação. Você pode definir múltiplos subagentes em uma única chamada --agents:
- macOS, Linux, WSL
- Windows PowerShell
--agents aceita JSON com os mesmos campos de frontmatter que subagentes baseados em arquivo: description, prompt, tools, disallowedTools, model, permissionMode, mcpServers, hooks, maxTurns, skills, initialPrompt, memory, effort, background, isolation e color. Use prompt para o prompt de sistema, equivalente ao corpo markdown em subagentes baseados em arquivo.
Subagentes gerenciados são implantados por administradores da organização. Coloque arquivos markdown em .claude/agents/ dentro do diretório de configurações gerenciadas, usando o mesmo formato de frontmatter que subagentes de projeto e usuário. Definições gerenciadas têm precedência sobre subagentes de projeto e usuário com o mesmo nome.
Subagentes de plugin vêm de plugins que você instalou. Eles aparecem em /agents junto com seus subagentes personalizados. Veja a referência de componentes de plugin para detalhes sobre como criar subagentes de plugin.
Por razões de segurança, subagentes de plugin não suportam os campos de frontmatter
hooks, mcpServers ou permissionMode. Estes campos são ignorados ao carregar agentes de um plugin. Se você precisar deles, copie o arquivo do agente para .claude/agents/ ou ~/.claude/agents/. Você também pode adicionar regras a permissions.allow em settings.json ou settings.local.json, mas estas regras se aplicam a toda a sessão, não apenas ao subagente do plugin.tools e model, com o corpo da definição anexado ao prompt de sistema do colega de trabalho como instruções adicionais. Veja equipes de agentes para quais campos de frontmatter se aplicam nesse caminho.
Escrever arquivos de subagente
Arquivos de subagente usam frontmatter YAML para configuração, seguido pelo prompt de sistema em Markdown:Subagentes são carregados no início da sessão. Se você adicionar ou editar um arquivo de subagente diretamente no disco, reinicie sua sessão para carregá-lo. Subagentes criados através da interface
/agents entram em efeito imediatamente sem uma reinicialização.cd não persistem entre chamadas de ferramentas Bash ou PowerShell e não afetam o diretório de trabalho da conversa principal. Para dar ao subagente uma cópia isolada do repositório em vez disso, defina isolation: worktree.
Campos de frontmatter suportados
Os seguintes campos podem ser usados no frontmatter YAML. Apenasname e description são obrigatórios.
| Field | Required | Description |
|---|---|---|
name | Yes | Identificador único usando letras minúsculas e hífens. Hooks recebem este valor como agent_type. O nome do arquivo não precisa corresponder |
description | Yes | Quando Claude deve delegar para este subagente |
tools | No | Ferramentas que o subagente pode usar. Herda todas as ferramentas se omitido. Para pré-carregar Skills no contexto, use o campo skills em vez de listar Skill aqui |
disallowedTools | No | Ferramentas a negar, removidas da lista herdada ou especificada |
model | No | Modelo a usar: sonnet, opus, haiku, fable, um ID de modelo completo (por exemplo, claude-opus-4-8), ou inherit. Padrão: inherit |
permissionMode | No | Modo de permissão: default, acceptEdits, auto, dontAsk, bypassPermissions, ou plan. Ignorado para subagentes de plugin |
maxTurns | No | Número máximo de turnos de agente antes do subagente parar |
skills | No | Skills a pré-carregar no contexto do subagente na inicialização. O conteúdo completo da skill é injetado, não apenas a descrição. Subagentes ainda podem invocar skills de projeto, usuário e plugin não listadas através da ferramenta Skill |
mcpServers | No | MCP servers disponíveis para este subagente. Cada entrada é um nome de servidor referenciando um servidor já configurado (por exemplo, "slack") ou uma definição inline com o nome do servidor como chave e uma configuração completa de MCP server como valor. Ignorado para subagentes de plugin |
hooks | No | Lifecycle hooks com escopo para este subagente. Ignorado para subagentes de plugin |
memory | No | Escopo de memória persistente: user, project, ou local. Habilita aprendizado entre sessões |
background | No | Defina como true para sempre executar este subagente como uma tarefa em background. Padrão: false |
effort | No | Nível de esforço quando este subagente está ativo. Sobrescreve o nível de esforço da sessão. Padrão: herda da sessão. Opções: low, medium, high, xhigh, max; os níveis disponíveis dependem do modelo |
isolation | No | Defina como worktree para executar o subagente em um git worktree temporário, dando-lhe uma cópia isolada do repositório ramificada por padrão a partir de sua branch padrão em vez do HEAD da sessão pai. O worktree é automaticamente limpo se o subagente não fizer alterações |
color | No | Cor de exibição para o subagente na lista de tarefas e transcrição. Aceita red, blue, green, yellow, purple, orange, pink, ou cyan |
initialPrompt | No | Auto-enviado como o primeiro turno do usuário quando este agente é executado como o agente da sessão principal (via --agent ou a configuração agent). Comandos e skills são processados. Preposto a qualquer prompt fornecido pelo usuário |
Escolher um modelo
O campomodel controla qual modelo de IA o subagente usa:
- Alias de modelo: Use um dos aliases disponíveis:
sonnet,opus,haiku, oufable - ID de modelo completo: Use um ID de modelo completo como
claude-opus-4-8ouclaude-sonnet-5. Aceita os mesmos valores que o flag--model - inherit: Use o mesmo modelo que a conversa principal
- Omitido: Se não especificado, padrão é
inherit(usa o mesmo modelo que a conversa principal)
model para essa invocação específica. Claude Code resolve o modelo do subagente nesta ordem:
- A variável de ambiente
CLAUDE_CODE_SUBAGENT_MODEL, quando definida para um alias de modelo ou ID de modelo - O parâmetro
modelpor invocação - O frontmatter
modelda definição do subagente - O modelo da conversa principal
CLAUDE_CODE_SUBAGENT_MODEL para inherit é o mesmo que deixá-lo indefinido: a resolução continua com o parâmetro model por invocação, depois o frontmatter. Em versões anteriores, inherit forçava subagentes para o modelo da conversa principal e ignorava ambas essas fontes.
O valor da variável de ambiente, parâmetro por invocação e valores de frontmatter são verificados contra a lista de permissões availableModels da sua organização. Um valor que se resolve para um modelo excluído não é usado e o subagente é executado no modelo herdado em vez disso.
Controlar capacidades do subagente
Você pode controlar o que subagentes podem fazer através de acesso a ferramentas, modos de permissão e regras condicionais.Ferramentas disponíveis
Subagentes herdam as ferramentas internas e ferramentas MCP disponíveis na conversa principal por padrão. As seguintes ferramentas dependem da interface ou estado de sessão da conversa principal e não estão disponíveis para subagentes, mesmo quando listadas no campotools:
AskUserQuestionEnterPlanModeExitPlanMode, a menos que opermissionModedo subagente sejaplanScheduleWakeupWaitForMcpServers
tools (lista de permissões) ou campo disallowedTools (lista de negação). Este exemplo usa tools para permitir exclusivamente Read, Grep, Glob e Bash. O subagente não pode editar arquivos, escrever arquivos ou usar qualquer ferramenta MCP:
disallowedTools para herdar todas as ferramentas da conversa principal exceto Write e Edit. O subagente mantém Bash, ferramentas MCP e tudo mais:
disallowedTools é aplicado primeiro, depois tools é resolvido contra o pool restante. Uma ferramenta listada em ambos é removida.
Ambos os campos aceitam padrões de nível de servidor MCP além de nomes de ferramentas exatos: mcp__<server> ou mcp__<server>__* concede ou remove todas as ferramentas do servidor nomeado. Em disallowedTools, mcp__* também remove todas as ferramentas MCP de qualquer servidor. Este exemplo remove todas as ferramentas do servidor MCP github enquanto mantém ferramentas de outros servidores e todas as ferramentas integradas:
Restringir quais subagentes podem ser gerados
Quando um agente é executado como thread principal comclaude --agent, ele pode gerar subagentes usando a ferramenta Agent. Para restringir quais tipos de subagente ele pode gerar, use a sintaxe Agent(agent_type) no campo tools.
Na versão 2.1.63, a ferramenta Task foi renomeada para Agent. Referências existentes de
Task(...) em configurações e definições de agente ainda funcionam como aliases.worker e researcher podem ser gerados. Se o agente tentar gerar qualquer outro tipo, a solicitação falha e o agente vê apenas os tipos permitidos em seu prompt. Para bloquear agentes específicos enquanto permite todos os outros, use permissions.deny em vez disso.
Para permitir gerar qualquer subagente sem restrições, use Agent sem parênteses:
Agent for omitido da lista tools inteiramente, o agente não pode gerar nenhum subagente.
A sintaxe de lista de permissões Agent(agent_type) se aplica apenas a um agente executado como thread principal com claude --agent. Em uma definição de subagente, listar Agent em tools permite que esse subagente gere subagentes aninhados, mas qualquer lista de tipo dentro dos parênteses é ignorada.
Escopo de MCP servers para um subagente
Use o campomcpServers para dar a um subagente acesso a MCP servers que não estão disponíveis na conversa principal. Servidores inline definidos aqui são conectados quando o subagente inicia e desconectados quando termina. Referências de string compartilham a conexão da sessão pai.
O campo
mcpServers se aplica em ambos os contextos onde um arquivo de agente pode ser executado:- Como um subagente, gerado através da ferramenta Agent ou uma @-menção
- Como a sessão principal, iniciada com
--agentou a configuraçãoagent
.mcp.json e arquivos de configurações..mcp.json (stdio, http, sse, ws), com chave pelo nome do servidor.
Para manter um MCP server fora da conversa principal inteiramente e evitar que suas descrições de ferramentas consumam contexto lá, defina-o inline aqui em vez de em .mcp.json. O subagente obtém as ferramentas; a conversa pai não.
A partir da v2.1.153, as restrições de MCP que se aplicam à sessão principal também cobrem servidores declarados no frontmatter do subagente:
--strict-mcp-confige--bare- Configuração de MCP gerenciada pela empresa
- Políticas
allowedMcpServersedeniedMcpServers
--strict-mcp-config não filtra servidores que você passa inline via --agents ou a opção agents do SDK, já que esses são entrada explícita do chamador.
Modos de permissão
O campopermissionMode controla como o subagente lida com prompts de permissão. Subagentes herdam o contexto de permissão da conversa principal e podem sobrescrever o modo, exceto quando o modo pai tem precedência conforme descrito abaixo.
| Mode | Behavior |
|---|---|
default | Verificação de permissão padrão com prompts |
acceptEdits | Auto-aceitar edições de arquivo e comandos comuns do sistema de arquivos para caminhos no diretório de trabalho ou additionalDirectories |
auto | Auto mode: um classificador de IA avalia cada chamada de ferramenta |
dontAsk | Auto-negar prompts de permissão (ferramentas explicitamente permitidas ainda funcionam) |
bypassPermissions | Pular prompts de permissão |
plan | Plan mode (exploração somente leitura) |
bypassPermissions ou acceptEdits, isso tem precedência e não pode ser sobrescrito. Se o pai usar auto mode, o subagente herda auto mode e qualquer permissionMode em seu frontmatter é ignorado: o classificador avalia as chamadas de ferramentas do subagente com as mesmas regras de bloqueio e permissão que a sessão pai.
Pré-carregar skills em subagentes
Use o camposkills para injetar conteúdo de skill no contexto de um subagente na inicialização. Isso dá ao subagente conhecimento de domínio sem exigir que ele descubra e carregue skills durante a execução.
Skill da lista tools ou adicione-o a disallowedTools.
Você não pode pré-carregar skills que definem disable-model-invocation: true, já que pré-carregar extrai do mesmo conjunto de skills que Claude pode invocar. Se uma skill listada estiver faltando ou desabilitada, Claude Code a ignora e registra um aviso no log de debug.
Isto é o inverso de executar uma skill em um subagente. Com
skills em um subagente, o subagente controla o prompt de sistema e carrega conteúdo de skill. Com context: fork em uma skill, o conteúdo de skill é injetado no agente que você especificar. Ambos usam o mesmo sistema subjacente.Habilitar memória persistente
O campomemory dá ao subagente um diretório persistente que sobrevive entre conversas. O subagente usa este diretório para construir conhecimento ao longo do tempo, como padrões de base de código, insights de debugging e decisões arquiteturais.
| Scope | Location | Use when |
|---|---|---|
user | ~/.claude/agent-memory/<name-of-agent>/ | o subagente deve lembrar aprendizados entre todos os projetos |
project | .claude/agent-memory/<name-of-agent>/ | o conhecimento do subagente é específico do projeto e compartilhável via controle de versão |
local | .claude/agent-memory-local/<name-of-agent>/ | o conhecimento do subagente é específico do projeto mas não deve ser verificado no controle de versão |
- O prompt de sistema do subagente inclui instruções para ler e escrever no diretório de memória.
- O prompt de sistema do subagente também inclui as primeiras 200 linhas ou 25KB de
MEMORY.mdno diretório de memória, o que for menor, com instruções para curarMEMORY.mdse exceder esse limite. - Ferramentas Read, Write e Edit são automaticamente habilitadas para que o subagente possa gerenciar seus arquivos de memória.
-
projecté o escopo padrão recomendado. Ele torna o conhecimento do subagente compartilhável via controle de versão. Useuserquando o conhecimento do subagente é amplamente aplicável entre projetos, oulocalquando o conhecimento não deve ser verificado no controle de versão. - Peça ao subagente para consultar sua memória antes de começar o trabalho: “Review this PR, and check your memory for patterns you’ve seen before.”
- Peça ao subagente para atualizar sua memória após completar uma tarefa: “Now that you’re done, save what you learned to your memory.” Ao longo do tempo, isso constrói uma base de conhecimento que torna o subagente mais eficaz.
-
Inclua instruções de memória diretamente no arquivo markdown do subagente para que ele mantenha proativamente sua própria base de conhecimento:
Regras condicionais com hooks
Para controle mais dinâmico sobre uso de ferramentas, use hooksPreToolUse para validar operações antes de serem executadas. Isso é útil quando você precisa permitir algumas operações de uma ferramenta enquanto bloqueia outras.
Este exemplo cria um subagente que apenas permite consultas de banco de dados somente leitura. O hook PreToolUse executa o script especificado em command antes de cada comando Bash ser executado:
shell: powershell à entrada de hook conforme mostrado em executando hooks em PowerShell.
Desabilitar subagentes específicos
Você pode impedir que Claude use subagentes específicos adicionando-os ao arraydeny em suas configurações. Use o formato Agent(subagent-name) onde subagent-name corresponde ao campo name do subagente.
--disallowedTools:
Definir hooks para subagentes
Subagentes podem definir hooks que são executados durante o ciclo de vida do subagente. Existem duas formas de configurar hooks:- No frontmatter do subagente: defina hooks que são executados apenas enquanto esse subagente específico está ativo
- Em
settings.json: defina hooks que são executados na sessão principal quando subagentes iniciam ou param
Hooks no frontmatter do subagente
Defina hooks diretamente no arquivo markdown do subagente. Estes hooks são executados apenas enquanto esse subagente específico está ativo e são limpos quando termina.Hooks de frontmatter disparam quando o agente é gerado como um subagente através da ferramenta Agent ou uma @-menção, e quando o agente é executado como a sessão principal via
--agent ou a configuração agent. No caso de sessão principal, eles são executados junto com qualquer hook definido em settings.json.| Event | Matcher input | When it fires |
|---|---|---|
PreToolUse | Nome da ferramenta | Antes do subagente usar uma ferramenta |
PostToolUse | Nome da ferramenta | Depois do subagente usar uma ferramenta |
Stop | (nenhum) | Quando o subagente termina (convertido para SubagentStop em tempo de execução) |
PreToolUse e executa um linter após edições de arquivo com PostToolUse:
Stop no frontmatter são automaticamente convertidos para eventos SubagentStop.
Hooks no nível do projeto para eventos de subagente
Configure hooks emsettings.json que respondem a eventos de ciclo de vida de subagente na sessão principal.
| Event | Matcher input | When it fires |
|---|---|---|
SubagentStart | Nome do tipo de agente | Quando um subagente começa a execução |
SubagentStop | Nome do tipo de agente | Quando um subagente completa |
name do frontmatter do agente para subagentes no nível de projeto e usuário, ou o identificador com escopo de plugin como my-plugin:db-agent para subagentes de plugin. Um nome com escopo contém dois-pontos, portanto é avaliado como uma expressão regular sem âncora; ancorá-lo com ^ e $, como em ^my-plugin:db-agent$, para corresponder apenas a esse agente.
Este exemplo executa um script de configuração apenas quando o subagente db-agent inicia, e um script de limpeza quando qualquer subagente para:
db-agent corresponde exatamente no Claude Code v2.1.195 ou posterior. Em versões anteriores, é avaliado como uma expressão regular sem âncora e também dispara para qualquer tipo de agente que o contenha, como prod-db-agent; ancorá-lo como ^db-agent$ nessas versões.
Veja Hooks para o formato de configuração de hook completo.
Trabalhar com subagentes
Entender delegação automática
Claude delega automaticamente tarefas baseado na descrição da tarefa em sua solicitação, no campodescription em configurações de subagente e no contexto atual. Para encorajar delegação proativa, inclua frases como “use proactively” no campo description do seu subagente.
Invocar subagentes explicitamente
Quando delegação automática não é suficiente, você pode solicitar um subagente você mesmo. Três padrões escalam de uma sugestão única para um padrão padrão em toda a sessão:- Linguagem natural: nomeie o subagente em seu prompt; Claude decide se deve delegar
- @-mention: garante que o subagente seja executado para uma tarefa
- Em toda a sessão: toda a sessão usa o prompt de sistema, restrições de ferramentas e modelo do subagente via flag
--agentou configuraçãoagent
@ e escolha o subagente do typeahead, da mesma forma que você @-menciona arquivos. Isso garante que esse subagente específico seja executado em vez de deixar a escolha para Claude:
my-plugin:code-reviewer ou my-plugin:review:security quando o plugin organiza agentes em subpastas. Subagentes em background nomeados atualmente em execução na sessão também aparecem no typeahead, mostrando seu status ao lado do nome.
Você também pode digitar a menção manualmente sem usar o picker: @agent-<name> para subagentes locais, ou @agent- seguido pelo nome com escopo para subagentes de plugin, por exemplo @agent-my-plugin:code-reviewer.
Execute toda a sessão como um subagente. Passe --agent <name> para iniciar uma sessão onde a thread principal em si assume o prompt de sistema, restrições de ferramentas e modelo do subagente:
--system-prompt faz. Arquivos CLAUDE.md e memória de projeto ainda carregam através do fluxo de mensagem normal. O nome do agente aparece como @<name> no cabeçalho de inicialização para que você possa confirmar que está ativo.
Isso funciona com subagentes integrados e personalizados, e a escolha persiste quando você retoma a sessão.
Para um subagente fornecido por plugin, você pode passar apenas o nome do agente e Claude Code o encontrará:
agents/, inclua a subpasta no nome com escopo, por exemplo claude --agent my-plugin:review:security.
Para torná-lo o padrão para cada sessão em um projeto, defina agent em .claude/settings.json:
Executar subagentes em foreground ou background
Subagentes podem ser executados em foreground ou background:- Subagentes em foreground bloqueiam a conversa principal até completar. Prompts de permissão são passados para você conforme surgem.
- Subagentes em background são executados concorrentemente enquanto você continua trabalhando. A partir da v2.1.186, quando um subagente em background atinge uma chamada de ferramenta que precisa de permissão, o prompt aparece em sua sessão principal e nomeia o subagente que está pedindo. Aprove para deixar o subagente continuar, ou pressione Esc para negar essa chamada de ferramenta sem parar o subagente. Antes da v2.1.186, subagentes em background auto-negavam qualquer chamada de ferramenta que teria solicitado.
- Pedir a Claude para “run this in the background”
- Pressionar Ctrl+B para colocar uma tarefa em background
CLAUDE_CODE_DISABLE_BACKGROUND_TASKS para 1. Veja Variáveis de ambiente.
Quando CLAUDE_CODE_FORK_SUBAGENT está definido para 1, cada spawn de subagente é executado em background independentemente do campo background. Prompts de permissão desses subagentes em background aparecem em sua sessão principal conforme descrito acima.
Padrões comuns
Isolar operações de alto volume
Um dos usos mais eficazes para subagentes é isolar operações que produzem grandes quantidades de saída. Executar testes, buscar documentação ou processar arquivos de log podem consumir contexto significativo. Ao delegar esses para um subagente, a saída verbosa fica no contexto do subagente enquanto apenas o resumo relevante retorna para sua conversa principal.Executar pesquisa em paralelo
Para investigações independentes, gere múltiplos subagentes para trabalhar simultaneamente:Encadear subagentes
Para fluxos de trabalho multi-etapas, peça a Claude para usar subagentes em sequência. Cada subagente completa sua tarefa e retorna resultados para Claude, que então passa contexto relevante para o próximo subagente.Escolher entre subagentes e conversa principal
Use a conversa principal quando:- A tarefa precisa de frequente ida e volta ou refinamento iterativo
- Múltiplas fases compartilham contexto significativo, como planejamento, implementação e testes
- Você está fazendo uma mudança rápida e direcionada
- Latência importa. Subagentes começam do zero e podem precisar de tempo para reunir contexto
- A tarefa produz saída verbosa que você não precisa em seu contexto principal
- Você quer aplicar restrições de ferramentas específicas ou permissões
- O trabalho é auto-contido e pode retornar um resumo
/btw em vez de um subagente. Ele vê seu contexto completo mas não tem acesso a ferramentas, e a resposta é descartada em vez de adicionada ao histórico.
Gerar subagentes aninhados
A partir do Claude Code v2.1.172, um subagente pode gerar seus próprios subagentes. Use isso quando uma tarefa delegada em si se divide em subtarefas paralelas, como um subagente revisor que distribui um verificador por descoberta, para que a saída intermediária nunca alcance sua conversa principal. Apenas o resumo do subagente de nível superior retorna para você. Um subagente aninhado é configurado da mesma forma que um de nível superior e é resolvido dos mesmos escopos. O painel de subagente abaixo da entrada de prompt mostra a árvore completa: cada linha exibe uma contagem(+N) de descendentes, e a partir da v2.1.193, abrir uma linha mostra os irmãos desse subagente e filhos diretos com um caminho de volta para main. A aba Running em /agents lista subagentes em execução como uma lista plana.
A profundidade é contada como o número de níveis de subagente abaixo da conversa principal, independentemente de cada nível ser executado em foreground ou background. Um subagente na profundidade cinco não recebe a ferramenta Agent e não pode gerar mais. O limite é fixo e não configurável.
A partir do Claude Code v2.1.187, a profundidade de um subagente em background é fixada quando ele é primeiro gerado, e retomar isso mais tarde não muda essa profundidade. Por exemplo, se sua conversa principal gera subagente A, e A gera um subagente em background B na profundidade dois, B ainda está na profundidade dois quando você o retoma diretamente da conversa principal. Retomar um subagente de um contexto mais raso não permite que ele gere níveis adicionais que o limite de profundidade já impediu.
Para prevenir um subagente específico de gerar outros, omita Agent de sua lista tools ou adicione-o a disallowedTools.
Um fork ainda não pode gerar outro fork. Pode gerar outros tipos de subagente, e esses contam para o limite de profundidade.
Gerenciar contexto de subagente
O que carrega na inicialização
Cada subagente começa com uma janela de contexto fresca e isolada. Ele não vê seu histórico de conversa, as skills que você já invocou, ou os arquivos que Claude já leu. Claude compõe uma mensagem de delegação que resume a tarefa, e o subagente trabalha a partir daí. A exceção é um fork, que herda a conversa pai em vez de começar do zero. O contexto inicial de um subagente não-fork contém:- Prompt de sistema: o prompt próprio do agente mais detalhes de ambiente que Claude Code acrescenta, não o prompt de sistema completo do Claude Code. Subagentes personalizados definem o seu no corpo markdown ou campo
prompt. Agentes integrados têm prompts predefinidos. - Mensagem de tarefa: o prompt de delegação que Claude escreve quando passa o trabalho.
- CLAUDE.md e memória: cada nível da hierarquia de memória que a conversa principal carrega, incluindo
~/.claude/CLAUDE.md, regras de projeto,CLAUDE.local.mde arquivos de política gerenciados. Os agentes integrados Explore e Plan pulam isso. - Status do Git: um snapshot tirado no início da sessão pai. Ausente quando o diretório de trabalho não é um repositório Git ou quando
includeGitInstructionséfalse. Explore e Plan pulam isso independentemente. - Skills pré-carregadas: conteúdo completo de qualquer skill nomeada no campo
skillsdo agente. Agentes integrados não pré-carregam skills.
vendor/”, reafirme-a no prompt que você dá a Claude ao delegar.
Retomar subagentes
Cada invocação de subagente cria uma nova instância com contexto fresco. Para continuar o trabalho de um subagente existente em vez de começar do zero, peça a Claude para retomá-lo. Subagentes retomados retêm seu histórico de conversa completo, incluindo todas as chamadas de ferramentas anteriores, resultados e raciocínio. O subagente continua exatamente de onde parou em vez de começar do zero. Quando um subagente completa, Claude recebe seu ID de agente. Os agentes integrados Explore e Plan são de uma única execução e não retornam ID de agente, então eles não podem ser retomados; usegeneral-purpose ou um subagente personalizado quando você precisar continuar o trabalho.
Claude usa a ferramenta SendMessage com o ID do agente como campo to para retomá-lo. A ferramenta SendMessage está sempre disponível para retomar subagentes por ID ou nome de agente. Mensagens de protocolo de equipe estruturadas como shutdown_request e plan_approval_response exigem que equipes de agentes estejam habilitadas.
Para retomar um subagente, peça a Claude para continuar o trabalho anterior:
SendMessage, ele auto-retoma em background sem exigir uma nova invocação de Agent.
Você também pode pedir a Claude pelo ID do agente se quiser referenciá-lo explicitamente, ou encontrar IDs nos arquivos de transcrição em ~/.claude/projects/{project}/{sessionId}/subagents/. Cada transcrição é armazenada como agent-{agentId}.jsonl.
Transcrições de subagente persistem independentemente da conversa principal:
- Compactação da conversa principal: Quando a conversa principal se compacta, transcrições de subagente não são afetadas. Elas são armazenadas em arquivos separados.
- Persistência de sessão: Transcrições de subagente persistem dentro de sua sessão. Você pode retomar um subagente após reiniciar Claude Code retomando a mesma sessão.
- Limpeza automática: Transcrições são limpas baseado na configuração
cleanupPeriodDays, que padrão é 30 dias.
Auto-compactação
Subagentes suportam compactação automática usando a mesma lógica que a conversa principal. A compactação é acionada sob as mesmas condições, eCLAUDE_AUTOCOMPACT_PCT_OVERRIDE se aplica a subagentes também. Veja variáveis de ambiente para quando a sobrescrita entra em efeito.
Eventos de compactação são registrados em arquivos de transcrição de subagente:
preTokens mostra quantos tokens foram usados antes da compactação ocorrer.
Bifurcar a conversa atual
Subagentes bifurcados requerem Claude Code v2.1.117 ou posterior. A partir da v2.1.161, o comando
/fork está habilitado por padrão; em versões anteriores, requer definir a variável de ambiente CLAUDE_CODE_FORK_SUBAGENT para 1. Deixar Claude gerar bifurcações é experimental e pode mudar em versões futuras. Esta capacidade também pode ser habilitada em sessões interativas como parte de um lançamento em fases.CLAUDE_CODE_FORK_SUBAGENT para 1 para habilitá-lo explicitamente ou para 0 para desabilitá-lo. A variável é respeitada em modo interativo e via SDK ou claude -p.
Habilitar o modo de bifurcação muda Claude Code de duas formas:
- Claude pode gerar uma bifurcação solicitando explicitamente o tipo de subagente
fork. Gerações sem um tipo de subagente ainda usam o subagente general-purpose, e subagentes nomeados como Explore ainda geram como antes. - Cada geração de subagente é executada em background, seja uma bifurcação ou um subagente nomeado. Defina
CLAUDE_CODE_DISABLE_BACKGROUND_TASKSpara1para manter gerações síncronas.
/fork seguido de uma diretiva, com ou sem a variável definida. Claude Code nomeia a bifurcação a partir das primeiras palavras da diretiva. O exemplo a seguir bifurca a conversa para rascunhar casos de teste enquanto você continua com a implementação na sessão principal:
Observar e orientar bifurcações em execução
Bifurcações em execução aparecem em um painel abaixo da entrada de prompt, com uma linha para a sessão principal e uma para cada bifurcação. Use estas teclas para interagir com o painel:| Key | Action |
|---|---|
↑ / ↓ | Mover entre linhas |
Enter | Abrir a transcrição da bifurcação selecionada e enviar mensagens de acompanhamento |
x | Descartar uma bifurcação terminada ou parar uma em execução |
Esc | Retornar foco para a entrada de prompt |
Como bifurcações diferem de subagentes nomeados
Uma bifurcação herda tudo que a sessão principal tem no momento em que é gerada. Um subagente nomeado começa a partir de sua própria definição.| Bifurcação | Subagente nomeado | |
|---|---|---|
| Context | Histórico de conversa completo | Contexto fresco com o prompt que você passa |
| System prompt and tools | Mesmo que a sessão principal | Da definição file do subagente |
| Model | Mesmo que a sessão principal | Do campo model do subagente |
| Permissions | Prompts aparecem em seu terminal | Prompts aparecem em sua sessão principal quando em execução em background |
| Prompt cache | Compartilhado com a sessão principal | Cache separado |
isolation: "worktree" para que as edições de arquivo da bifurcação sejam escritas em um git worktree separado em vez de seu checkout.
Limitações
DefinirCLAUDE_CODE_FORK_SUBAGENT=1 habilita fork mode em sessões interativas, modo não-interativo e o Agent SDK; definir para 0 desabilita fork mode em todos os lugares, incluindo qualquer lançamento no servidor. Uma bifurcação não pode gerar bifurcações adicionais.
Subagentes de exemplo
Estes exemplos demonstram padrões eficazes para construir subagentes. Use-os como pontos de partida, ou gere uma versão personalizada com Claude.Revisor de código
Um subagente somente leitura que revisa código sem modificá-lo. Este exemplo mostra como projetar um subagente focado com acesso limitado a ferramentas (sem Edit ou Write) e um prompt detalhado que especifica exatamente o que procurar e como formatar a saída.Debugger
Um subagente que pode analisar e corrigir problemas. Diferentemente do revisor de código, este inclui Edit porque corrigir bugs requer modificar código. O prompt fornece um fluxo de trabalho claro de diagnóstico para verificação.Cientista de dados
Um subagente específico de domínio para trabalho de análise de dados. Este exemplo mostra como criar subagentes para fluxos de trabalho especializados fora de tarefas de codificação típicas. Ele explicitamente definemodel: sonnet para análise mais capaz.
Validador de consulta de banco de dados
Um subagente que permite acesso Bash mas valida comandos para permitir apenas consultas SQL somente leitura. Este exemplo mostra como usar hooksPreToolUse para validação condicional quando você precisa de controle mais fino do que o campo tools fornece.
command em sua configuração de hook:
shell: powershell à entrada de hook. Veja executando hooks em PowerShell.
O hook recebe JSON via stdin com o comando Bash em tool_input.command. Código de saída 2 bloqueia a operação e alimenta a mensagem de erro de volta para Claude. Veja Hooks para detalhes sobre códigos de saída e Hook input para o schema de entrada completo.
Próximos passos
Agora que você entende subagentes, explore estes recursos relacionados:- Distribuir subagentes com plugins para compartilhar subagentes entre equipes ou projetos
- Executar Claude Code programaticamente com o Agent SDK para CI/CD e automação
- Usar MCP servers para dar aos subagentes acesso a ferramentas e dados externos