Leer en inglés

Compartir a través de


Bloquear la ejecución de una aplicación al finalizar una operación asincrónica

Las aplicaciones que no pueden seguir realizando otro trabajo mientras esperan los resultados de una operación asincrónica se deben bloquear hasta que se complete la operación. Use una de las opciones siguientes para bloquear el subproceso principal de la aplicación mientras se espera a que se complete una operación asincrónica:

Las aplicaciones que usan el método EndNombreDeLaOperación para el bloqueo hasta que se completa una operación asincrónica normalmente llamarán al método BeginNombreDeLaOperación, realizarán cualquier trabajo que se pueda realizar sin los resultados de la operación y luego llamarán a EndNombreDeLaOperación.

Ejemplo

En el ejemplo de código siguiente se explica cómo utilizar los métodos asincrónicos en la clase Dns para recuperar información del sistema de nombres de dominio de un equipo especificado por el usuario. Tenga en cuenta que null (Nothing en Visual Basic) se pasa para los parámetros BeginGetHostByNamerequestCallback y stateObject, porque estos argumentos no son necesarios cuando se usa este método.

/*
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;

namespace Examples.AdvancedProgramming.AsynchronousOperations
{
    public class BlockUntilOperationCompletes
    {
        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.
            // This example does not use a delegate or user-supplied object
            // so the last two arguments are null.
            IAsyncResult result = Dns.BeginGetHostEntry(args[0], null, null);
            Console.WriteLine("Processing your request for information...");
            // Do any additional work that can be done here.
            try
            {
                // EndGetHostEntry blocks until the process completes.
                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($"{aliases[i]}");
                    }
                }
                if (addresses.Length > 0)
                {
                    Console.WriteLine("Addresses");
                    for (int i = 0; i < addresses.Length; i++)
                    {
                        Console.WriteLine($"{addresses[i].ToString()}");
                    }
                }
            }
            catch (SocketException e)
            {
                Console.WriteLine($"An exception occurred while processing the request: {e.Message}");
            }
        }
    }
}

Vea también


Recursos adicionales

Documentación