Information
The topic you requested is included in another documentation set. For convenience, it's displayed below. Choose Switch to see the topic in its original location.

WaitHandle.WaitAll Method (WaitHandle[])

Waits for all the elements in the specified array to receive a signal.

Namespace: System.Threading
Assembly: mscorlib (in mscorlib.dll)

public static bool WaitAll (
	WaitHandle[] waitHandles
)
public static boolean WaitAll (
	WaitHandle[] waitHandles
)
public static function WaitAll (
	waitHandles : WaitHandle[]
) : boolean

Parameters

waitHandles

A WaitHandle array containing the objects for which the current instance will wait. This array cannot contain multiple references to the same object.

Return Value

true when every element in waitHandles has received a signal; otherwise the method never returns.

Exception typeCondition

ArgumentNullException

The waitHandles parameter is a null reference (Nothing in Visual Basic). -or-

One or more of the objects in the waitHandles array are a null reference (Nothing in Visual Basic).

-or-

waitHandles is an array with no elements, and the .NET Framework version is 2.0.

DuplicateWaitObjectException

The waitHandles array contains elements that are duplicates.

NotSupportedException

The number of objects in waitHandles is greater than the system permits.

-or-

The STAThreadAttribute attribute is applied to the thread procedure for the current thread, and waitHandles contains more than one element.

ApplicationException

waitHandles is an array with no elements, and the .NET Framework version is 1.0 or 1.1.

AbandonedMutexException

The wait terminated because a thread exited without releasing a mutex. This exception is not thrown on Windows 98 or Windows Millennium Edition.

AbandonedMutexException is new in the .NET Framework version 2.0. In previous versions, the WaitAll method returns true when a mutex is abandoned. An abandoned mutex indicates a serious coding error. The exception contains information useful for debugging.

The WaitAll method returns when all the handles are signaled. On some implementations, if more than 64 handles are passed, a NotSupportedException is thrown. If the array contains duplicates, the call fails with a DuplicateWaitObjectException.

NoteNote

The WaitAll method is not supported on threads that have STAThreadAttribute.

Calling this method overload is equivalent to calling the WaitAll(WaitHandle[],Int32,Boolean) method overload and specifying -1 (or Timeout.Infinite) for millisecondsTimeout and true for exitContext.

The following code example shows how to use the thread pool to asynchronously create and write to a group of files. Each write operation is queued as a work item and signals when it is finished. The main thread waits for all the items to signal and then exits.

using System;
using System.IO;
using System.Security.Permissions;
using System.Threading;

// Request permission to create and write files to C:\TestTest.
[assembly: FileIOPermissionAttribute(SecurityAction.RequestMinimum, 
     All = @"C:\TestTest")]

class Test
{
    static void Main()
    {
        const int numberOfFiles = 5;
        string dirName = @"C:\TestTest";
        string fileName;

        byte[] byteArray;
        Random randomGenerator = new Random();

        ManualResetEvent[] manualEvents = 
            new ManualResetEvent[numberOfFiles];
        State stateInfo;

        if(!Directory.Exists(dirName))
        {
            Directory.CreateDirectory(dirName);
        }

        // Queue the work items that create and write to the files.
        for(int i = 0; i < numberOfFiles; i++)
        {
            fileName = string.Concat(
                dirName, @"\Test", i.ToString(), ".dat");

            // Create random data to write to the file.
            byteArray = new byte[1000000];
            randomGenerator.NextBytes(byteArray);

            manualEvents[i] = new ManualResetEvent(false);

            stateInfo = 
                new State(fileName, byteArray, manualEvents[i]);

            ThreadPool.QueueUserWorkItem(new WaitCallback(
                Writer.WriteToFile), stateInfo);
        }
    
        // Since ThreadPool threads are background threads, 
        // wait for the work items to signal before exiting.
        WaitHandle.WaitAll(manualEvents);
        Console.WriteLine("Files written - main exiting.");
    }
}

// Maintain state to pass to WriteToFile.
class State
{
    public string fileName;
    public byte[] byteArray;
    public ManualResetEvent manualEvent;

    public State(string fileName, byte[] byteArray, 
        ManualResetEvent manualEvent)
    {
        this.fileName = fileName;
        this.byteArray = byteArray;
        this.manualEvent = manualEvent;
    }
}

class Writer
{
    static int workItemCount = 0;
    Writer() {}

    public static void WriteToFile(object state)
    {
        int workItemNumber = workItemCount;
        Interlocked.Increment(ref workItemCount);
        Console.WriteLine("Starting work item {0}.",
            workItemNumber.ToString());
        State stateInfo = (State)state;
        FileStream fileWriter = null;

        // Create and write to the file.
        try
        {
            fileWriter = new FileStream(
                stateInfo.fileName, FileMode.Create);
            fileWriter.Write(stateInfo.byteArray, 
                0, stateInfo.byteArray.Length);
        }
        finally
        {
            if(fileWriter != null)
            {
                fileWriter.Close();
            }

            // Signal Main that the work item has finished.
            Console.WriteLine("Ending work item {0}.", 
                workItemNumber.ToString());
            stateInfo.manualEvent.Set();
        }
    }
}

import System.*;
import System.IO.*;
import System.Security.Permissions.*;
import System.Threading.*;
import System.Threading.Thread;

// Request permission to create and write files to C:\TestTest.
/** @assembly FileIOPermissionAttribute(SecurityAction.RequestMinimum,
    All = "C:\\TestTest")
 */

class Test
{
    public static void main(String[] args)
    {
        final int numberOfFiles = 5;
        String dirName = "C:\\TestTest";
        String fileName;
        ubyte byteArray[];
        Random randomGenerator = new Random();
        ManualResetEvent manualEvents[] = new ManualResetEvent[numberOfFiles];
        State stateInfo;

        if (!(Directory.Exists(dirName))) {
            Directory.CreateDirectory(dirName);
        }

        // Queue the work items that create and write to the files.
        for (int i = 0; i < numberOfFiles; i++) {
            fileName = String.Concat(dirName, "\\Test", String.valueOf(i),
                ".dat");

            // Create random data to write to the file.
            byteArray = new ubyte[1000000];
            randomGenerator.NextBytes(byteArray);
            manualEvents.set_Item(i, new ManualResetEvent(false));
            stateInfo = new State(fileName, byteArray, manualEvents[i]);
            ThreadPool.QueueUserWorkItem(new WaitCallback(Writer.WriteToFile),
                stateInfo);
        }

        // Since ThreadPool threads are background threads, 
        // wait for the work items to signal before exiting.
        WaitHandle.WaitAll(manualEvents);
        Console.WriteLine("Files written - main exiting.");
    } //main
} //Test

// Maintain state to pass to WriteToFile.
class State
{
    public String fileName;
    public ubyte byteArray[];
    public ManualResetEvent manualEvent;

    public State(String fileName, ubyte byteArray[],
            ManualResetEvent manualEvent)
    {
        this.fileName = fileName;
        this.byteArray = byteArray;
        this.manualEvent = manualEvent;
    } //State
} //State

class Writer
{
    private static int workItemCount = 0;

    Writer()
    {
    } //Writer

    public static void WriteToFile(Object state)
    {
        int workItemNumber = workItemCount;

        Interlocked.Increment(workItemCount);
        Console.WriteLine("Starting work item {0}.",
            String.valueOf(workItemNumber));

        State stateInfo = ((State)(state));
        FileStream fileWriter = null;

        // Create and write to the file.
        try{
            fileWriter = new FileStream(stateInfo.fileName, FileMode.Create);
            fileWriter.Write(stateInfo.byteArray, 0, 
                stateInfo.byteArray.length);
        }
        finally {
            if ( fileWriter  != null  ) {
                fileWriter.Close();
            }
         
            // Signal Main that the work item has finished.
            Console.WriteLine("Ending work item {0}.", 
                String.valueOf(workItemNumber));
            stateInfo.manualEvent.Set();
      }
    } //WriteToFile
} //Writer

Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition

The .NET Framework does not support all versions of every platform. For a list of the supported versions, see System Requirements.

.NET Framework

Supported in: 2.0, 1.1, 1.0

Community Additions

Show:
© 2014 Microsoft