Практическое руководство. Объединение параллельных и последовательных запросов LINQ

Этот пример демонстрирует применение метода AsSequential, который запрашивает последовательную обработку в PLINQ всех последующих операторов текущего запроса. Обычно последовательная обработка выполняется медленнее, чем параллельная, но иногда она необходима, чтобы гарантировать правильные результаты.

Примечание

Этот пример предназначен для демонстрации использования и может выполняться не быстрее аналогичного последовательного запроса LINQ to Objects. См. дополнительные сведения об ускорении выполнения в PLINQ.

Пример

Следующий пример демонстрирует одну из ситуаций, для которой необходимо AsSequential, поскольку здесь важно сохранить порядок, установленный предыдущим предложением запроса.

// Paste into PLINQDataSample class.
static void SequentialDemo()
{
    var orders = GetOrders();
    var query = (from order in orders.AsParallel()
                 orderby order.OrderID
                 select new
                 {
                     order.OrderID,
                     OrderedOn = order.OrderDate,
                     ShippedOn = order.ShippedDate
                 })
                 .AsSequential().Take(5);
}
' Paste into PLINQDataSample class
Shared Sub SequentialDemo()

    Dim orders = GetOrders()
    Dim query = From ord In orders.AsParallel()
                Order By ord.OrderID
                Select New With
                {
                    ord.OrderID,
                    ord.OrderDate,
                    ord.ShippedDate
                }

    Dim query2 = query.AsSequential().Take(5)

    For Each item In query2
        Console.WriteLine("{0}, {1}, {2}", item.OrderDate, item.OrderID, item.ShippedDate)
    Next
End Sub

Компиляция кода

Чтобы скомпилировать и запустить этот код, вставьте его в проект Пример данных PLINQ, добавьте строку с вызовом этого метода из Main и нажмите клавишу F5.

См. также