C#
// Version secuencial
foreach (var item in sourceCollection)
{
Process(item);
}
// Equivalente paralelo
Parallel.ForEach(sourceCollection, item => Process(item));
Cuando un bucle paralelo se ejecuta, la TPL crea particiones del origen de datos para que el bucle pueda funcionar simultáneamente en varias partes. En segundo plano, el programador de tareas crea particiones de la tarea según los recursos del sistema y la carga de trabajo. Cuando es posible, el programador redistribuye el trabajo entre varios subprocesos y procesadores si se desequilibra la carga de trabajo.
Los métodos Parallel.ForEach y Parallel.For tienen varias sobrecargas que permiten detener o ejecutar la ejecución de bucles, supervisar el estado del bucle en otros subprocesos, mantener el estado de subprocesos locales, finalizar los objetos de subprocesos locales, controlar el grado de simultaneidad, etc. Los tipos de aplicación auxiliar que habilitan esta funcionalidad son ParallelLoopState, ParallelOptions y ParallelLoopResult, CancellationToken y CancellationTokenSource.
Para obtener más información, vea Paralelismo de datos (Task Parallel Library).
PLINQ admite el paralelismo de datos con sintaxis declarativa o de consulta. Para obtener más información, vea Parallel LINQ (PLINQ).
No hay comentarios:
Publicar un comentario