BlockingCollection<T>.TakeFromAny Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Usa um item de qualquer uma das instâncias especificadas BlockingCollection<T> .
Sobrecargas
| Nome | Description |
|---|---|
| TakeFromAny(BlockingCollection<T>[], T) |
Usa um item de qualquer uma das instâncias especificadas BlockingCollection<T> . |
| TakeFromAny(BlockingCollection<T>[], T, CancellationToken) |
Usa um item de qualquer uma das instâncias especificadas BlockingCollection<T> ao observar o token de cancelamento especificado. |
TakeFromAny(BlockingCollection<T>[], T)
Usa um item de qualquer uma das instâncias especificadas BlockingCollection<T> .
public:
static int TakeFromAny(cli::array <System::Collections::Concurrent::BlockingCollection<T> ^> ^ collections, [Runtime::InteropServices::Out] T % item);
public static int TakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T item);
static member TakeFromAny : System.Collections.Concurrent.BlockingCollection<'T>[] * 'T -> int
Public Shared Function TakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T) As Integer
Parâmetros
- collections
- BlockingCollection<T>[]
A matriz de coleções.
- item
- T
O item que foi removido de uma das coleções.
Retornos
O índice da coleção na collections matriz da qual o item foi removido.
Exceções
Pelo menos uma das BlockingCollection<T> instâncias foi descartada.
O collections argumento é nulo.
A contagem collections é maior que o tamanho máximo de 62 para STA e 63 para MTA.
O collections argumento é uma matriz de 0 comprimentos ou contém um elemento nulo ou CompleteAdding() foi chamado na coleção.
Pelo menos uma das coleções subjacentes foi modificada fora de sua BlockingCollection<T> instância.
Comentários
Uma chamada para TakeFromAny pode ser bloqueada até que um item esteja disponível para ser removido.
Confira também
Aplica-se a
TakeFromAny(BlockingCollection<T>[], T, CancellationToken)
Usa um item de qualquer uma das instâncias especificadas BlockingCollection<T> ao observar o token de cancelamento especificado.
public:
static int TakeFromAny(cli::array <System::Collections::Concurrent::BlockingCollection<T> ^> ^ collections, [Runtime::InteropServices::Out] T % item, System::Threading::CancellationToken cancellationToken);
public static int TakeFromAny(System.Collections.Concurrent.BlockingCollection<T>[] collections, out T item, System.Threading.CancellationToken cancellationToken);
static member TakeFromAny : System.Collections.Concurrent.BlockingCollection<'T>[] * 'T * System.Threading.CancellationToken -> int
Public Shared Function TakeFromAny (collections As BlockingCollection(Of T)(), ByRef item As T, cancellationToken As CancellationToken) As Integer
Parâmetros
- collections
- BlockingCollection<T>[]
A matriz de coleções.
- item
- T
O item que foi removido de uma das coleções.
- cancellationToken
- CancellationToken
Um token de cancelamento a ser observado.
Retornos
O índice da coleção na collections matriz da qual o item foi removido.
Exceções
O CancellationToken cancelamento foi cancelado.
Pelo menos uma das coleções subjacentes foi modificada fora de sua BlockingCollection<T> instância.
O collections argumento é nulo.
A contagem collections é maior que o tamanho máximo de 62 para STA e 63 para MTA.
O collections argumento é uma matriz de 0 comprimentos ou contém um elemento nulo ou CompleteAdding() foi chamado na coleção.
Pelo menos uma das BlockingCollection<T> instâncias foi descartada.
Comentários
Uma chamada para TakeFromAny pode ser bloqueada até que um item esteja disponível para ser removido. O método retornará antecipadamente com um OperationCanceledException se o token for cancelado.