Partager via


Async (Visual Basic)

Le modificateur Async, spécifie qu'une méthode, une expression lambda, ou une méthode anonyme est asynchrone. Ces méthodes sont nommées méthodes asynchrones.

Une méthode async offre un moyen pratique d'exécuter un travail potentiellement long sans bloquer le thread de l'appelant. L'appelant d'une méthode async peut reprendre son travail sans attendre la fin de la méthode async.

Notes

Les mots clés Async et Await ont été introduits dans Visual Studio 2012.Pour une présentation de la programmation asynchrone, consultez Programmation asynchrone avec Async et Await (C# et Visual Basic).

L'exemple suivant illustre la structure d'une méthode asynchrone. Par convention, le nom d'une méthode asynchrone se termine par le suffixe "Async".

Public Async Function ExampleMethodAsync() As Task(Of Integer)
    ' . . .

    ' At the Await expression, execution in this method is suspended and,
    ' if AwaitedProcessAsync has not already finished, control returns
    ' to the caller of ExampleMethodAsync. When the awaited task is 
    ' completed, this method resumes execution. 
    Dim exampleInt As Integer = Await AwaitedProcessAsync()

    ' . . .

    ' The return statement completes the task. Any method that is 
    ' awaiting ExampleMethodAsync can now get the integer result.
    Return exampleInt
End Function

En général, une méthode que le mot clé Async modifie contient au moins une instruction ou une expression await. La méthode fonctionne de façon synchrone jusqu'à ce qu'elle atteigne le premier Await, après quoi elle s'interrompt jusqu'à ce que la tâche attendue se termine. Entre-temps, l'appelant récupère le contrôle de la méthode async. Si la méthode ne contient pas une expression ou une instruction Await, la méthode n'est pas interrompue et s'exécute comme une méthode synchrone. Un avertissement du compilateur vous signale toutes les méthodes async qui ne contiennent pas Await, car cette situation peut indiquer une erreur. Pour plus d'informations, consultez le erreur de compilation.

Le mot clé Async est un mot clé non réservé. C'est un mot clé lorsqu'il modifie une méthode ou une expression lambda. Dans tous les autres contextes, il est interprété comme un identificateur.

Types de retours

Une méthode async est soit une procédure Sub, ou une procédure Fonction qui possède un type de retour de Task ou de Task. La méthode ne peut pas déclarer de paramètres ByRef.

Vous spécifiez Task(Of TResult) comme type de retour d'une méthode async si l'instruction return de la méthode possède un opérande de type TResult. Utilisez Task si aucune valeur significative n'est retournée lorsque la méthode est terminée. Autrement dit, un appel à la méthode retourne Task, mais lorsque Task est terminé, aucune instruction Await qui attend un Task ne produit une valeur de résultat.

Les sous-routines Async sont principalement utilisées pour définir des gestionnaires d'événements où une procédure Sub est requise. L'appelant d'une sous-routine async ne peut pas l'attendre et ne peut pas intercepter les exceptions levées par la méthode.

Pour plus d'informations et d'exemples, consultez Types de retour Async (C# et Visual Basic).

Exemple

Les exemples suivants montrent un gestionnaire d'événements async, une expression lambda async, et une méthode async. Pour obtenir un exemple complet qui utilise ces éléments semblables, consultez Procédure pas à pas : accès au Web avec Async et Await (C# et Visual Basic). Vous pouvez télécharger le code de procédure depuis Exemples de code du développeur.

' An event handler must be a Sub procedure.
Async Sub button1_Click(sender As Object, e As RoutedEventArgs) Handles button1.Click
    textBox1.Clear()
    ' SumPageSizesAsync is a method that returns a Task.
    Await SumPageSizesAsync()
    textBox1.Text = vbCrLf & "Control returned to button1_Click."
End Sub


' The following async lambda expression creates an equivalent anonymous
' event handler.
AddHandler button1.Click, Async Sub(sender, e)
                              textBox1.Clear()
                              ' SumPageSizesAsync is a method that returns a Task.
                              Await SumPageSizesAsync()
                              textBox1.Text = vbCrLf & "Control returned to button1_Click."
                          End Sub 


' The following async method returns a Task(Of T).
' A typical call awaits the Byte array result:
'      Dim result As Byte() = Await GetURLContents("https://msdn.com")
Private Async Function GetURLContentsAsync(url As String) As Task(Of Byte())

    ' The downloaded resource ends up in the variable named content.
    Dim content = New MemoryStream()

    ' Initialize an HttpWebRequest for the current URL.
    Dim webReq = CType(WebRequest.Create(url), HttpWebRequest)

    ' Send the request to the Internet resource and wait for
    ' the response.
    Using response As WebResponse = Await webReq.GetResponseAsync()
        ' Get the data stream that is associated with the specified URL.
        Using responseStream As Stream = response.GetResponseStream()
            ' Read the bytes in responseStream and copy them to content.  
            ' CopyToAsync returns a Task, not a Task<T>.
            Await responseStream.CopyToAsync(content)
        End Using
    End Using

    ' Return the result as a byte array.
    Return content.ToArray()
End Function

Voir aussi

Tâches

Procédure pas à pas : accès au Web avec Async et Await (C# et Visual Basic)

Référence

Await, opérateur (Visual Basic)

AsyncStateMachineAttribute

Concepts

Programmation asynchrone avec Async et Await (C# et Visual Basic)