

La AWS SDK per .NET V3 è entrata in modalità manutenzione.

[Ti consigliamo di migrare alla V4.AWS SDK per .NET](https://docs.aws.amazon.com/sdk-for-net/v4/developer-guide/welcome.html) Per ulteriori dettagli e informazioni su come eseguire la migrazione, consulta il nostro annuncio sulla modalità di [manutenzione](https://aws.amazon.com/blogs/developer/aws-sdk-for-net-v3-maintenance-mode-announcement/).

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

# AWS asincrono APIs per.NET
<a name="sdk-net-async-api"></a>

 AWS SDK per .NET utilizza il *Task-based Asynchronous Pattern (TAP) per la sua implementazione asincrona.* Per ulteriori informazioni sul TAP, vedere [Task-based](https://learn.microsoft.com/en-us/dotnet/standard/asynchronous-programming-patterns/task-based-asynchronous-pattern-tap) Asynchronous Pattern (TAP) su docs.microsoft.com.

Questo argomento offre una panoramica su come utilizzare TAP nelle chiamate ai clienti di assistenza. AWS 

I metodi asincroni nell' AWS SDK per .NET API sono operazioni basate sulla `Task` classe o sulla classe. `Task<TResult>` [https://learn.microsoft.com/en-us/dotnet/api/system.threading.tasks.task](https://learn.microsoft.com/en-us/dotnet/api/system.threading.tasks.task)

Quando questi metodi API vengono chiamati nel codice, devono essere chiamati all'interno di una funzione dichiarata con la `async` parola chiave, come illustrato nell'esempio seguente.

```
static async Task Main(string[] args)
{
  ...
  // Call the function that contains the asynchronous API method.
  // Could also call the asynchronous API method directly from Main
  //  because Main is declared async
  var response = await ListBucketsAsync();
  Console.WriteLine($"Number of buckets: {response.Buckets.Count}");
  ...
}

// Async method to get a list of Amazon S3 buckets.
private static async Task<ListBucketsResponse> ListBucketsAsync()
{
  ...
  var response = await s3Client.ListBucketsAsync();
  return response;
}
```

Come illustrato nel frammento di codice precedente, l'ambito preferito per la `async` dichiarazione è la funzione. `Main` L'impostazione di questo `async` ambito garantisce che tutte le chiamate ai client di AWS servizio debbano essere asincrone. Se per qualche motivo non puoi `Main` dichiarare di essere asincrono, puoi utilizzare la `async` parola chiave su funzioni diverse da `Main` e quindi chiamare i metodi API da lì, come mostrato nell'esempio seguente. 

```
static void Main(string[] args)
{
  ...
  Task<ListBucketsResponse> response = ListBucketsAsync();
  Console.WriteLine($"Number of buckets: {response.Result.Buckets.Count}");
  ...
}

// Async method to get a list of Amazon S3 buckets.
private static async Task<ListBucketsResponse> ListBucketsAsync()
{
  ...
  var response = await s3Client.ListBucketsAsync();
  return response;
}
```

Notate la `Task<>` sintassi speciale necessaria `Main` quando utilizzate questo modello. Inoltre, è necessario utilizzare il **`Result`**membro della risposta per ottenere i dati.

Puoi vedere esempi completi di chiamate asincrone ai client di AWS assistenza nella [Fai un breve tour](quick-start.md) sezione ([Semplice app multipiattaforma](quick-start-s3-1-cross.md)e[Semplice app basata su Windows](quick-start-s3-1-winvs.md)) e in. [Esempi di codice con indicazioniLibrerie e framework di alto livello](tutorials-examples.md)