BlockingCollection<T>.TryTakeFromAny Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>.
Sobrecargas
TryTakeFromAny(BlockingCollection<T>[], T) |
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>. |
TryTakeFromAny(BlockingCollection<T>[], T, Int32) |
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>. |
TryTakeFromAny(BlockingCollection<T>[], T, Int32, CancellationToken) |
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>. |
TryTakeFromAny(BlockingCollection<T>[], T, TimeSpan) |
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>. |
TryTakeFromAny(BlockingCollection<T>[], T)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>.
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
Parámetros
- collections
- BlockingCollection<T>[]
Matriz de colecciones.
- item
- T
Elemento que se quitó de una de las colecciones.
Devoluciones
Índice de la colección en la matriz collections
de la que se quitó el elemento o -1 si no se pudo quitar el elemento.
Excepciones
Se ha eliminado al menos una de las instancias de BlockingCollection<T>.
El argumento collections
es null.
El recuento de collections
es mayor que el tamaño máximo de 62 para STA y 63 para MTA.
El argumento collections
es una matriz de longitud 0 o contiene un elemento nulo.
Al menos una de las colecciones subyacentes se modificó fuera de su instancia BlockingCollection<T>.
Ejemplos
En el siguiente ejemplo, se muestra cómo utilizar el método BlockingCollection<T>.TryTakeFromAny:
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
Comentarios
Una llamada a TryTakeFromAny puede bloquearse hasta que un elemento esté disponible para quitarse.
Consulte también
Se aplica a
TryTakeFromAny(BlockingCollection<T>[], T, Int32)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>.
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
Parámetros
- collections
- BlockingCollection<T>[]
Matriz de colecciones de la que se va a quitar un elemento.
- item
- T
Elemento que se quitó de una de las colecciones.
- millisecondsTimeout
- Int32
El número de milisegundos que se van a esperar a que se quite el elemento o Infinite (-1) espere indefinidamente.
Devoluciones
Índice de la colección en la matriz collections
de la que se quitó el elemento o -1 si no se pudo quitar el elemento.
Excepciones
Se ha eliminado al menos una de las instancias de BlockingCollection<T>.
El argumento collections
es null.
millisecondsTimeout
es un número negativo distinto de-1, que representa un tiempo de espera infinito.
o bien
El recuento de collections
es mayor que el tamaño máximo de 62 para STA y 63 para MTA.
El argumento collections
es una matriz de longitud 0 o contiene un elemento nulo.
Al menos una de las colecciones subyacentes se modificó fuera de su instancia BlockingCollection<T>.
Comentarios
Una llamada a TryTakeFromAny puede bloquearse hasta que un elemento esté disponible para quitarse.
Consulte también
Se aplica a
TryTakeFromAny(BlockingCollection<T>[], T, Int32, CancellationToken)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>.
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
Parámetros
- collections
- BlockingCollection<T>[]
Matriz de colecciones de la que se va a quitar un elemento.
- item
- T
Elemento que se quitó de una de las colecciones.
- millisecondsTimeout
- Int32
El número de milisegundos que se van a esperar a que se quite el elemento o Infinite (-1) espere indefinidamente.
- cancellationToken
- CancellationToken
Token de cancelación que se va a observar.
Devoluciones
Índice de la colección en la matriz collections
de la que se quitó el elemento o -1 si no se pudo quitar el elemento.
Excepciones
CancellationToken se cancela.
Al menos una de las colecciones subyacentes se modificó fuera de su instancia BlockingCollection<T>.
El argumento collections
es null.
millisecondsTimeout
es un número negativo distinto de-1, que representa un tiempo de espera infinito.
o bien
El recuento de collections
es mayor que el tamaño máximo de 62 para STA y 63 para MTA.
El argumento collections
es una matriz de longitud 0 o contiene un elemento nulo.
Se ha eliminado al menos una de las instancias de BlockingCollection<T>.
Comentarios
Una llamada a TryTakeFromAny puede bloquearse hasta que un elemento esté disponible para quitarse.
Consulte también
Se aplica a
TryTakeFromAny(BlockingCollection<T>[], T, TimeSpan)
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
- Source:
- BlockingCollection.cs
Intenta quitar un elemento de cualquiera de las instancias especificadas de BlockingCollection<T>.
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
Parámetros
- collections
- BlockingCollection<T>[]
Matriz de colecciones.
- item
- T
Elemento que se quitó de una de las colecciones.
- timeout
- TimeSpan
Estructura TimeSpan que representa el número de milisegundos de espera o estructura TimeSpan que representa -1 milisegundos para esperar indefinidamente.
Devoluciones
Índice de la colección en la matriz collections
de la que se quitó el elemento o -1 si no se pudo quitar el elemento.
Excepciones
Se ha eliminado al menos una de las instancias de BlockingCollection<T>.
El argumento collections
es null.
timeout
es un número negativo distinto de -1 milisegundos, que representa un tiempo de espera infinito.
O bien
timeout
es mayor que Int32.MaxValue.
o bien
El recuento de collections
es mayor que el tamaño máximo de 62 para STA y 63 para MTA.
El argumento collections
es una matriz de longitud 0 o contiene un elemento nulo.
Al menos una de las colecciones subyacentes se modificó fuera de su instancia BlockingCollection<T>.
Comentarios
Una llamada a TryTakeFromAny puede bloquearse hasta que un elemento esté disponible para quitarse.