Se você precisa de múltiplos agentes trabalhando em paralelo e se comunicando entre si, consulte equipes de agentes em vez disso. Subagentes funcionam dentro de uma única sessão; equipes de agentes coordenam entre sessões separadas.
- 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
- Plan
- General-purpose
- Other
Um agente rápido e somente leitura otimizado para pesquisar e analisar bases de código.
- Model: Haiku (rápido, baixa latência)
- Tools: Ferramentas somente leitura (acesso negado a ferramentas Write e Edit)
- Purpose: Descoberta de arquivos, pesquisa de código, exploração de base de código
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
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 fornece uma interface interativa para gerenciar subagentes. Execute /agents para:
- Visualizar todos os subagentes disponíveis (integrados, usuário, projeto e plugin)
- Criar novos subagentes com configuração guiada ou geração por Claude
- Editar configuração de subagente existente e acesso a ferramentas
- Deletar subagentes personalizados
- Ver quais subagentes estão ativos quando duplicatas existem
claude agents. Isso mostra agentes agrupados por fonte e indica quais são substituídos por definições de prioridade mais alta.
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, o local de prioridade mais alta vence.| Location | Scope | Priority | How to create |
|---|---|---|---|
--agents CLI flag | Sessão atual | 1 (mais alta) | Passar JSON ao iniciar Claude Code |
.claude/agents/ | Projeto atual | 2 | Interativo ou manual |
~/.claude/agents/ | Todos os seus projetos | 3 | Interativo ou manual |
Diretório agents/ do Plugin | Onde o plugin está habilitado | 4 (mais baixa) | Instalado com 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 usuário (~/.claude/agents/) são subagentes pessoais disponíveis em todos os seus projetos.
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:
--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 e isolation. Use prompt para o prompt de sistema, equivalente ao corpo markdown em subagentes baseados em arquivo.
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.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ê criar um subagente adicionando manualmente um arquivo, reinicie sua sessão ou use
/agents para carregá-lo imediatamente.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 |
description | Yes | Quando Claude deve delegar para este subagente |
tools | No | Ferramentas que o subagente pode usar. Herda todas as ferramentas se omitido |
disallowedTools | No | Ferramentas a negar, removidas da lista herdada ou especificada |
model | No | Modelo a usar: sonnet, opus, haiku, um ID de modelo completo (por exemplo, claude-opus-4-6), ou inherit. Padrão: inherit |
permissionMode | No | Modo de permissão: default, acceptEdits, dontAsk, bypassPermissions, ou plan |
maxTurns | No | Número máximo de turnos de agente antes do subagente parar |
skills | No | Skills a carregar no contexto do subagente na inicialização. O conteúdo completo da skill é injetado, não apenas disponibilizado para invocação. Subagentes não herdam skills da conversa pai |
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 |
hooks | No | Lifecycle hooks com escopo para este subagente |
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, max (apenas Opus 4.6) |
isolation | No | Defina como worktree para executar o subagente em um git worktree temporário, dando-lhe uma cópia isolada do repositório. O worktree é automaticamente limpo se o subagente não fizer alterações |
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, ouhaiku - ID de modelo completo: Use um ID de modelo completo como
claude-opus-4-6ouclaude-sonnet-4-6. 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, se definida - O parâmetro
modelpor invocação - O frontmatter
modelda definição do subagente - O modelo da conversa principal
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 podem usar qualquer uma das ferramentas internas do Claude Code. Por padrão, subagentes herdam todas as ferramentas da conversa principal, incluindo ferramentas MCP. Para restringir ferramentas, use o campotools (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.
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. Esta restrição se aplica apenas a agentes executados como thread principal com claude --agent. Subagentes não podem gerar outros subagentes, então Agent(agent_type) não tem efeito em definições de subagente.
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.
Cada entrada na lista é uma definição de servidor inline ou uma string referenciando um MCP server já configurado em sua sessão:
.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.
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 |
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, 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.
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 de
MEMORY.mdno diretório de memória, com instruções para curarMEMORY.mdse exceder 200 linhas. - Ferramentas Read, Write e Edit são automaticamente habilitadas para que o subagente possa gerenciar seus arquivos de memória.
Dicas de memória persistente
-
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:
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. Todos os eventos de hook são suportados. Os eventos mais comuns para subagentes são:| 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 |
db-agent inicia, e um script de limpeza quando qualquer subagente para:
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:
<plugin-name>:<agent-name>. Você também pode digitar a menção manualmente sem usar o picker: @agent-<name> para subagentes locais, ou @agent-<plugin-name>:<agent-name> para subagentes de plugin.
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, passe o nome com escopo: claude --agent <plugin-name>:<agent-name>.
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 (bloqueante) ou background (concorrente):- Subagentes em foreground bloqueiam a conversa principal até completar. Prompts de permissão e perguntas de esclarecimento (como
AskUserQuestion) são passados para você. - Subagentes em background são executados concorrentemente enquanto você continua trabalhando. Antes de iniciar, Claude Code solicita quaisquer permissões de ferramentas que o subagente precisará, garantindo que ele tenha as aprovações necessárias antecipadamente. Uma vez em execução, o subagente herda essas permissões e auto-nega qualquer coisa não pré-aprovada. Se um subagente em background precisa fazer perguntas de esclarecimento, essa chamada de ferramenta falha mas o subagente continua.
- 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.
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 (planejamento → implementação → 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.
Subagentes não podem gerar outros subagentes. Se seu fluxo de trabalho requer delegação aninhada, use Skills ou encadeie subagentes da conversa principal.
Gerenciar contexto de subagente
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. Claude usa a ferramentaSendMessage com o ID do agente como campo to para retomá-lo. 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(padrão: 30 dias).
Auto-compactação
Subagentes suportam compactação automática usando a mesma lógica que a conversa principal. Por padrão, auto-compactação é acionada em aproximadamente 95% de capacidade. Para acionar compactação mais cedo, definaCLAUDE_AUTOCOMPACT_PCT_OVERRIDE para uma porcentagem mais baixa (por exemplo, 50). Veja variáveis de ambiente para detalhes.
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.
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:
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