Panoramica
Claude Agent SDK supporta due modalità di input distinte per interagire con gli agenti:- Modalità Streaming Input (Predefinita e Consigliata) - Una sessione persistente e interattiva
- Single Message Input - Query una tantum che utilizzano lo stato della sessione e la ripresa
Modalità Streaming Input (Consigliata)
La modalità streaming input è il modo preferito per utilizzare Claude Agent SDK. Fornisce accesso completo alle capacità dell’agente e consente esperienze ricche e interattive. Consente all’agente di operare come un processo di lunga durata che accetta input dell’utente, gestisce interruzioni, visualizza richieste di autorizzazione e gestisce la gestione della sessione.Come Funziona
Vantaggi
Caricamenti di Immagini
Allegate immagini direttamente ai messaggi per l’analisi visiva e la comprensione
Messaggi in Coda
Inviate più messaggi che vengono elaborati sequenzialmente, con la possibilità di interrompere
Integrazione Tool
Accesso completo a tutti i tool e ai server MCP personalizzati durante la sessione
Feedback in Tempo Reale
Vedete le risposte mentre vengono generate, non solo i risultati finali
Persistenza del Contesto
Mantenete il contesto della conversazione su più turni naturalmente
Esempio di Implementazione
In TypeScript SDK, se il vostro generatore di messaggi genera un’eccezione, ad esempio quando un file che legge è mancante, il flusso termina con un errore che recita
Claude Code process aborted by user invece dell’errore originale, quindi controllate il codice all’interno del vostro generatore per primo quando vedete quel messaggio. L’errore potrebbe anche essere preceduto da una lunga riga minificata del codice sorgente SDK raggruppato, quindi leggete fino alla fine dell’output per il testo dell’errore.In Python SDK, un’eccezione del generatore viene registrata a livello di debug e la sessione si blocca senza sollevare, quindi se una sessione di streaming si blocca senza output, abilitate la registrazione di debug e controllate il vostro generatore.Single Message Input
Single message input è più semplice ma più limitato.Quando Utilizzare Single Message Input
Utilizzate single message input quando:- Avete bisogno di una risposta una tantum
- Non avete bisogno di allegati di immagini o metodi di controllo mid-session
- Dovete operare in un ambiente senza stato, come una funzione lambda
Limitazioni
Se una query termina con un risultato di errore, comeerror_max_turns, una singola chiamata query() genera un errore che include il testo dell’errore dopo aver restituito il messaggio di risultato finale, quindi avvolgete il ciclo in un blocco try se il vostro codice deve continuare. Consultate Gestire il risultato per i sottotipi di risultato.