Kniga-Online.club
» » » » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Читать бесплатно Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю. Жанр: Базы данных год 2004. Так же читаем полные версии (весь текст) онлайн без регистрации и SMS на сайте kniga-online.club или прочесть краткое содержание, предисловие (аннотацию), описание и ознакомиться с отзывами (комментариями) о произведении.
Перейти на страницу:

through

nothing

business

another

looking

prisoner

Cruncher

Longest word is: undistinguishable

Помочь удостовериться в том, что приложение задействует все доступные процессоры машины, может параллельный вызов методов FindTenMostCommon() и FindLongestWord(). Для этого модифицируйте метод GetStats():

void GetStats()

{

  // Получить слова из электронной книги.

  string[] words = _theEBook.Split(

    new char[] { ' ', 'u000A', ',', '.', ';', ':', '-', '?', '/' },

    StringSplitOptions.RemoveEmptyEntries);

  string[] tenMostCommon = null;

  string longestWord = string.Empty;

  Parallel.Invoke(

    () =>

    {

      // Найти 10 наиболее часто встречающихся слов.

      tenMostCommon = FindTenMostCommon(words);

    },

    () =>

    {

      // Найти самое длинное слово.

      longestWord = FindLongestWord(words);

    });

  // Когда все задачи завершены, построить строку,

  // показывающую все статистические данные.

  ...

}

Метод Parallel.Invoke() ожидает передачи в качестве параметра массива делегатов Action<>, который предоставляется косвенно с применением лямбда-выражения. В то время как вывод идентичен, преимущество заключается в том, что библиотека TPL теперь будет использовать все доступные процессоры машины для вызова каждого метода параллельно, если подобное возможно.

Запросы Parallel LINQ (PLINQ)

В завершение знакомства с библиотекой TPL следует отметить, что существует еще один способ встраивания параллельных задач в приложения .NET Core. При желании можно применять набор расширяющих методов, которые позволяют конструировать запрос LINQ, распределяющий свою рабочую нагрузку по параллельным потокам (когда это возможно). Соответственно запросы LINQ, которые спроектированы для параллельного выполнения, называются запросами Parallel LINQ (PLINQ).

Подобно параллельному коду, написанному с использованием класса Parallel, в PLINQ имеется опция игнорирования запроса на обработку коллекции параллельным образом, если понадобится. Инфраструктура PLINQ оптимизирована во многих отношениях, включая определение того, не будет ли запрос на самом деле более эффективно выполняться в синхронной манере.

Во время выполнения PLINQ анализирует общую структуру запроса, и если есть вероятность, что запрос выиграет от распараллеливания, то он будет выполняться параллельно. Однако если распараллеливание запроса ухудшит производительность, то PLINQ просто запустит запрос последовательно. Когда возникает выбор между потенциально затратным (в плане ресурсов) параллельным алгоритмом и экономным последовательным, предпочтение по умолчанию отдается последовательному алгоритму.

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

Необходимые расширяющие методы находятся в классе ParallelEnumerable из пространства имен System.Linq. В табл. 15.5 описаны некоторые полезные расширяющие методы PLINQ.

Чтобы взглянуть на PLINQ в действии, создайте проект консольного приложения по имени PLINQDataProcessingWithCancellation и импортируйте в него пространства имен System.Linq, System.Threading и System.Threading.Tasks (если это еще не сделано). После начала обработки запускается новая задача, выполняющая запрос LINQ, который просматривает крупный массив целых чисел в поиске элементов, удовлетворяющих условию, что остаток от их деления на 3 дает 0. Вот непараллельная версия такого запроса:

using System;

using System.Linq;

using System.Threading;

using System.Threading.Tasks;

Console.WriteLine("Start any key to start processing");

                // Нажмите любую клавишу, чтобы начать обработку

Console.ReadKey();

Console.WriteLine("Processing");

Task.Factory.StartNew(ProcessIntData);

Console.ReadLine();

void ProcessIntData()

{

  // Получить очень большой массив целых чисел.

  int[] source = Enumerable.Range(1, 10_000_000).ToArray();

  // Найти числа, для которых истинно условие num % 3 == О,

  // и возвратить их в убывающем порядке.

  int[] modThreeIsZero = (

    from num in source

    where num % 3 == 0

    orderby num descending

    select num).ToArray();

  // Вывести количество найденных чисел

  Console.WriteLine($"Found {modThreeIsZero.Count()} numbers

                      that match query!");

}

Создание запроса PLINQ

Чтобы проинформировать библиотеку TPL о выполнении запроса в параллельном режиме (если такое возможно), необходимо использовать расширяющий метод AsParallel():

Перейти на страницу:

Троелсен Эндрю читать все книги автора по порядку

Троелсен Эндрю - все книги автора в одном месте читать по порядку полные версии на сайте онлайн библиотеки kniga-online.club.


Язык программирования C#9 и платформа .NET5 отзывы

Отзывы читателей о книге Язык программирования C#9 и платформа .NET5, автор: Троелсен Эндрю. Читайте комментарии и мнения людей о произведении.


Уважаемые читатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.

  • 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
  • 2. Просьба отказаться от оскорблений, угроз и запугиваний.
  • 3. Просьба отказаться от нецензурной лексики.
  • 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.

Надеемся на Ваше понимание и благоразумие. С уважением, администратор kniga-online.


Прокомментировать
Подтвердите что вы не робот:*
Подтвердите что вы не робот:*