Blocco dell'esecuzione dell'applicazione tramite AsyncWaitHandle
Aggiornamento: novembre 2007
È necessario bloccare le applicazioni che non consentono di eseguire altre attività in attesa dei risultati di un'operazione asincrona fino al completamento di quest'ultima. Utilizzare una delle opzioni indicate di seguito per bloccare il thread principale dell'applicazione durante l'attesa del completamento di un'operazione asincrona.
Utilizzare la proprietà AsyncWaitHandle dell'oggetto IAsyncResult restituito dal metodo BeginNomeOperazione dell'operazione asincrona. Tale approccio verrà descritto nel presente argomento.
Chiamare il metodo EndNomeOperazione dell'operazione asincrona. Per un esempio in cui venga illustrato questo approccio, vedere Blocco dell'esecuzione dell'applicazione terminando un'operazione asincrona.
Le applicazioni in cui vengono utilizzati uno o più oggetti WaitHandle da bloccare fino al completamento di un'operazione asincrona, in genere, chiamano il metodo BeginNomeOperazione, eseguono le attività eseguibili senza i risultati dell'operazione e quindi si bloccano fino a quando l'operazione o le operazioni asincrone vengono completate. Un'applicazione può essere bloccata su una sola operazione chiamando uno dei metodi WaitOne mediante la proprietà AsyncWaitHandle. Per eseguire il blocco durante l'attesa del completamento di un insieme di operazioni asincrone, memorizzare gli oggetti AsyncWaitHandle associati in una matrice e chiamare uno dei metodi WaitAll. Per eseguire il blocco durante l'attesa del completamento di una delle operazioni asincrone di un insieme, memorizzare gli oggetti AsyncWaitHandle associati in una matrice e chiamare uno dei metodi WaitAny.
Esempio
Nell'esempio di codice riportato di seguito viene illustrato come utilizzare i metodi asincroni nella classe DNS per recuperare informazioni DNS (Domain Name System) relative a un computer specificato dall'utente. Nell'esempio viene illustrata l'applicazione del blocco mediante l'oggetto WaitHandle associato all'operazione asincrona. Per i parametri requestCallback e stateObject del metodo BeginGetHostByName viene passata la parola chiave null (Nothing in Visual Basic) in quanto tali parametri non sono richiesti per l'utilizzo di questo approccio.
' The following example demonstrates using asynchronous methods to
' get Domain Name System information for the specified host computer.
Imports System
Imports System.Net
Imports System.Net.Sockets
Imports System.Threading
namespace Examples.AdvancedProgramming.AsynchronousOperations
Public Class WaitUntilOperationCompletes
Public Shared Sub Main(args() as String)
' Make sure the caller supplied a host name.
If(args.Length = 0)
' Print a message and exit.
Console.WriteLine("You must specify the name of a host computer.")
End
End If
' Start the asynchronous request for DNS information.
Dim result as IAsyncResult= Dns.BeginGetHostEntry(args(0), Nothing, Nothing)
Console.WriteLine("Processing request for information...")
' Wait until the operation completes.
result.AsyncWaitHandle.WaitOne()
' The operation completed. Process the results.
Try
' Get the results.
Dim host as IPHostEntry = Dns.EndGetHostEntry(result)
Dim aliases() as String = host.Aliases
Dim addresses() as IPAddress= host.AddressList
Dim i as Integer
If aliases.Length > 0
Console.WriteLine("Aliases")
For i = 0 To aliases.Length -1
Console.WriteLine("{0}", aliases(i))
Next i
End If
If addresses.Length > 0
Console.WriteLine("Addresses")
For i = 0 To addresses.Length -1
Console.WriteLine("{0}", addresses(i).ToString())
Next i
End If
Catch e as SocketException
Console.WriteLine("An exception occurred while processing the request: {0}" _
, e.Message)
End Try
End Sub
End Class
End Namespace
/*
The following example demonstrates using asynchronous methods to
get Domain Name System information for the specified host computer.
*/
using System;
using System.Net;
using System.Net.Sockets;
using System.Threading;
namespace Examples.AdvancedProgramming.AsynchronousOperations
{
public class WaitUntilOperationCompletes
{
public static void Main(string[] args)
{
// Make sure the caller supplied a host name.
if (args.Length == 0 || args[0].Length == 0)
{
// Print a message and exit.
Console.WriteLine("You must specify the name of a host computer.");
return;
}
// Start the asynchronous request for DNS information.
IAsyncResult result = Dns.BeginGetHostEntry(args[0], null, null);
Console.WriteLine("Processing request for information...");
// Wait until the operation completes.
result.AsyncWaitHandle.WaitOne();
// The operation completed. Process the results.
try
{
// Get the results.
IPHostEntry host = Dns.EndGetHostEntry(result);
string[] aliases = host.Aliases;
IPAddress[] addresses = host.AddressList;
if (aliases.Length > 0)
{
Console.WriteLine("Aliases");
for (int i = 0; i < aliases.Length; i++)
{
Console.WriteLine("{0}", aliases[i]);
}
}
if (addresses.Length > 0)
{
Console.WriteLine("Addresses");
for (int i = 0; i < addresses.Length; i++)
{
Console.WriteLine("{0}",addresses[i].ToString());
}
}
}
catch (SocketException e)
{
Console.WriteLine("Exception occurred while processing the request: {0}",
e.Message);
}
}
}
}
Vedere anche
Concetti
Cenni preliminari sul modello asincrono basato su eventi