BlockingCollection<T>.TryTakeFromAny Method    
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Tries to remove an item from any one of the specified BlockingCollection<T> instances.
Overloads
| TryTakeFromAny(BlockingCollection<T>[], T) | Tries to remove an item from any one of the specified BlockingCollection<T> instances. | 
| TryTakeFromAny(BlockingCollection<T>[], T, Int32) | Tries to remove an item from any one of the specified BlockingCollection<T> instances. | 
| TryTakeFromAny(BlockingCollection<T>[], T, Int32, CancellationToken) | Tries to remove an item from any one of the specified BlockingCollection<T> instances. | 
| TryTakeFromAny(BlockingCollection<T>[], T, TimeSpan) | Tries to remove an item from any one of the specified BlockingCollection<T> instances. | 
TryTakeFromAny(BlockingCollection<T>[], T)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Tries to remove an item from any one of the specified BlockingCollection<T> instances.
public:
 static int TryTakeFromAny(cli::array <System::Collections::Concurrent::BlockingCollection<T> ^> ^ collections, [Runtime::InteropServices::Out] T % item);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T item);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T? item);static member TryTakeFromAny : System.Collections.Concurrent.BlockingCollection<'T>[] * 'T -> intPublic Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T) As IntegerParameters
- collections
- BlockingCollection<T>[]
The array of collections.
- item
- T
The item that was removed from one of the collections.
Returns
The index of the collection in the collections array from which the item was removed, or -1 if an item could not be removed.
Exceptions
At least one of the BlockingCollection<T> instances has been disposed.
The collections argument is null.
The count of collections is greater than the maximum size of 62 for STA and 63 for MTA.
The collections argument is a 0-length array or contains a null element.
At least one of the underlying collections was modified outside of its BlockingCollection<T> instance.
Examples
The following example shows how to use the BlockingCollection<T>.TryTakeFromAny method:
class FromToAnyDemo
{
    // Demonstrates:
    //      Bounded BlockingCollection<T>
    //      BlockingCollection<T>.TryAddToAny()
    //      BlockingCollection<T>.TryTakeFromAny()
    public static void BC_FromToAny()
    {
        BlockingCollection<int>[] bcs = new BlockingCollection<int>[2];
        bcs[0] = new BlockingCollection<int>(5); // collection bounded to 5 items
        bcs[1] = new BlockingCollection<int>(5); // collection bounded to 5 items
        // Should be able to add 10 items w/o blocking
        int numFailures = 0;
        for (int i = 0; i < 10; i++)
        {
            if (BlockingCollection<int>.TryAddToAny(bcs, i) == -1) numFailures++;
        }
        Console.WriteLine("TryAddToAny: {0} failures (should be 0)", numFailures);
        // Should be able to retrieve 10 items
        int numItems = 0;
        int item;
        while (BlockingCollection<int>.TryTakeFromAny(bcs, out item) != -1) numItems++;
        Console.WriteLine("TryTakeFromAny: retrieved {0} items (should be 10)", numItems);
    }
}
module FromToAnyDemo =
    // Demonstrates:
    //      Bounded BlockingCollection<T>
    //      BlockingCollection<T>.TryAddToAny()
    //      BlockingCollection<T>.TryTakeFromAny()
    let blockingCollectionFromToAny () =
        let bcs = 
            [|
                new BlockingCollection<int>(5) // collection bounded to 5 items
                new BlockingCollection<int>(5) // collection bounded to 5 items
             |]
        // Should be able to add 10 items w/o blocking
        let mutable numFailures = 0;
        for i = 0 to 9 do
            if BlockingCollection<int>.TryAddToAny(bcs, i) = -1 then
                numFailures <- numFailures + 1
        printfn $"TryAddToAny: {numFailures} failures (should be 0)"
        // Should be able to retrieve 10 items
        let mutable numItems = 0
        let mutable item = 0
        while BlockingCollection<int>.TryTakeFromAny(bcs, &item) <> -1 do
            numItems <- numItems + 1
        printfn $"TryTakeFromAny: retrieved {numItems} items (should be 10)"
'Imports System.Threading.Tasks
'Imports System.Collections.Concurrent
' Demonstrates:
' Bounded BlockingCollection<T>
' BlockingCollection<T>.TryAddToAny()
' BlockingCollection<T>.TryTakeFromAny()
Class ToAnyDemo
    Shared Sub BC_ToAny()
        Dim bcs As BlockingCollection(Of Integer)() = New BlockingCollection(Of Integer)(1) {}
        bcs(0) = New BlockingCollection(Of Integer)(5)
        ' collection bounded to 5 items
        bcs(1) = New BlockingCollection(Of Integer)(5)
        ' collection bounded to 5 items
        ' Should be able to add 10 items w/o blocking
        Dim numFailures As Integer = 0
        For i As Integer = 0 To 9
            If BlockingCollection(Of Integer).TryAddToAny(bcs, i) = -1 Then
                numFailures += 1
            End If
        Next
        Console.WriteLine("TryAddToAny: {0} failures (should be 0)", numFailures)
        ' Should be able to retrieve 10 items
        Dim numItems As Integer = 0
        Dim item As Integer
        While BlockingCollection(Of Integer).TryTakeFromAny(bcs, item) <> -1
            numItems += 1
        End While
        Console.WriteLine("TryTakeFromAny: retrieved {0} items (should be 10)", numItems)
    End Sub
End Class
Remarks
A call to TryTakeFromAny may block until an item is available to be removed.
See also
Applies to
TryTakeFromAny(BlockingCollection<T>[], T, Int32)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Tries to remove an item from any one of the specified BlockingCollection<T> instances.
public:
 static int TryTakeFromAny(cli::array <System::Collections::Concurrent::BlockingCollection<T> ^> ^ collections, [Runtime::InteropServices::Out] T % item, int millisecondsTimeout);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T item, int millisecondsTimeout);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T? item, int millisecondsTimeout);static member TryTakeFromAny : System.Collections.Concurrent.BlockingCollection<'T>[] * 'T * int -> intPublic Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T, millisecondsTimeout As Integer) As IntegerParameters
- collections
- BlockingCollection<T>[]
The array of collections to remove an item from.
- item
- T
The item that was removed from one of the collections.
- millisecondsTimeout
- Int32
The number of milliseconds to wait for the item to be removed, or Infinite (-1) to wait indefinitely.
Returns
The index of the collection in the collections array from which the item was removed, or -1 if an item could not be removed.
Exceptions
At least one of the BlockingCollection<T> instances has been disposed.
The collections argument is null.
millisecondsTimeout is a negative number other than -1, which represents an infinite time-out.
-or-
The count of collections is greater than the maximum size of 62 for STA and 63 for MTA.
The collections argument is a 0-length array or contains a null element.
At least one of the underlying collections was modified outside of its BlockingCollection<T> instance.
Remarks
A call to TryTakeFromAny may block until an item is available to be removed.
See also
Applies to
TryTakeFromAny(BlockingCollection<T>[], T, Int32, CancellationToken)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Tries to remove an item from any one of the specified BlockingCollection<T> instances.
public:
 static int TryTakeFromAny(cli::array <System::Collections::Concurrent::BlockingCollection<T> ^> ^ collections, [Runtime::InteropServices::Out] T % item, int millisecondsTimeout, System::Threading::CancellationToken cancellationToken);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T item, int millisecondsTimeout, System.Threading.CancellationToken cancellationToken);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T? item, int millisecondsTimeout, System.Threading.CancellationToken cancellationToken);static member TryTakeFromAny : System.Collections.Concurrent.BlockingCollection<'T>[] * 'T * int * System.Threading.CancellationToken -> intPublic Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T, millisecondsTimeout As Integer, cancellationToken As CancellationToken) As IntegerParameters
- collections
- BlockingCollection<T>[]
The array of collections to remove an item from.
- item
- T
The item that was removed from one of the collections.
- millisecondsTimeout
- Int32
The number of milliseconds to wait for the item to be removed, or Infinite (-1) to wait indefinitely.
- cancellationToken
- CancellationToken
A cancellation token to observe.
Returns
The index of the collection in the collections array from which the item was removed, or -1 if an item could not be removed.
Exceptions
The CancellationToken is canceled.
At least one of the underlying collections was modified outside of its BlockingCollection<T> instance.
The collections argument is null.
millisecondsTimeout is a negative number other than -1, which represents an infinite time-out.
-or-
The count of collections is greater than the maximum size of 62 for STA and 63 for MTA.
The collections argument is a 0-length array or contains a null element.
At least one of the BlockingCollection<T> instances has been disposed.
Remarks
A call to TryTakeFromAny may block until an item is available to be removed.
See also
Applies to
TryTakeFromAny(BlockingCollection<T>[], T, TimeSpan)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Tries to remove an item from any one of the specified BlockingCollection<T> instances.
public:
 static int TryTakeFromAny(cli::array <System::Collections::Concurrent::BlockingCollection<T> ^> ^ collections, [Runtime::InteropServices::Out] T % item, TimeSpan timeout);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T item, TimeSpan timeout);public static int TryTakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T? item, TimeSpan timeout);static member TryTakeFromAny : System.Collections.Concurrent.BlockingCollection<'T>[] * 'T * TimeSpan -> intPublic Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T, timeout As TimeSpan) As IntegerParameters
- collections
- BlockingCollection<T>[]
The array of collections.
- item
- T
The item that was removed from one of the collections.
- timeout
- TimeSpan
A TimeSpan that represents the number of milliseconds to wait, or a TimeSpan that represents -1 milliseconds to wait indefinitely.
Returns
The index of the collection in the collections array from which the item was removed, or -1 if an item could not be removed.
Exceptions
At least one of the BlockingCollection<T> instances has been disposed.
The collections argument is null.
timeout is a negative number other than -1 milliseconds, which represents an infinite time-out
-or-
timeout is greater than Int32.MaxValue.
-or-
The count of collections is greater than the maximum size of 62 for STA and 63 for MTA.
The collections argument is a 0-length array or contains a null element.
At least one of the underlying collections was modified outside of its BlockingCollection<T> instance.
Remarks
A call to TryTakeFromAny may block until an item is available to be removed.