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
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 -> int
Public Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T) As Integer
Parameters
- 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
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 -> int
Public Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T, millisecondsTimeout As Integer) As Integer
Parameters
- 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
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 -> int
Public Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T, millisecondsTimeout As Integer, cancellationToken As CancellationToken) As Integer
Parameters
- 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
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 -> int
Public Shared Function TryTakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T, timeout As TimeSpan) As Integer
Parameters
- 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.