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

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

На нашем литературном портале можно бесплатно читать книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю, Троелсен Эндрю . Жанр: Базы данных. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале litmir.org.
Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
Название: Язык программирования C#9 и платформа .NET5
Дата добавления: 22 август 2024
Количество просмотров: 244
Читать онлайн

Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних просмотр данного контента СТРОГО ЗАПРЕЩЕН! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту readbookfedya@gmail.com для удаления материала

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

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

В 10-м издании книги описаны новейшие возможности языка C# 9 и .NET 5 вместе с подробным "закулисным" обсуждением, призванным расширить навыки критического мышления разработчиков, когда речь идет об их ремесле.

Книга охватывает ASP.NET Core, Entity Framework Core и многое другое наряду с последними обновлениями унифицированной платформы .NET, начиная с улучшений показателей производительности настольных приложений Windows в .NET 5 и обновления инструментария XAML и заканчивая расширенным рассмотрением файлов данных и способов обработки данных.

Все примеры кода были переписаны с учетом возможностей последнего выпуска C# 9.

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

Обработка запроса на отмену

В текущий пример можно внести еще одно улучшение — предоставить пользователю способ для останова обработки данных изображений путем щелчка на второй кнопке Cancel (Отмена). К счастью, методы Parallel.For() и Parallel.ForEach() поддерживают отмену за счет использования маркеров отмены. При вызове методов на объекте Parallel им можно передавать объект ParallelOptions, который в свою очередь содержит объект CancellationTokenSource.

Первым делом определите в производном от Window классе закрытую переменную-член _cancelToken типа CancellationTokenSource:

public partial class MainWindow :Window

{

  // Новая переменная уровня Window.

  private CancellationTokenSource _cancelToken =

      new CancellationTokenSource();

  ...

}

Обновите обработчик события Click:

private void cmdCancel_

Click(object sender, EventArgs e)

{

 // Используется для сообщения всем рабочим потокам о необходимости останова!

  _cancelToken.Cancel();

}

Теперь можно заняться необходимыми модификациями метода ProcessFiles(). Вот его финальная реализация:

private void ProcessFiles()

{

<b>  // Использовать экземпляр ParallelOptions для хранения CancellationToken.</b>

  ParallelOptions parOpts = new ParallelOptions();

  parOpts.CancellationToken = _cancelToken.Token;

  parOpts.MaxDegreeOfParallelism = System.Environment.ProcessorCount;

  // Загрузить все файлы *.jpg и создать новый каталог

  // для модифицированных данных.

  string[] files = Directory.GetFiles(@&quot;.TestPictures&quot;, &quot;*.jpg&quot;,

                                      SearchOption.AllDirectories);

  string outputDirectory = @&quot;.ModifiedPictures&quot;;

  Directory.CreateDirectory(outputDirectory);

  try

  {

    // Обработать данные изображения в параллельном режиме!

    Parallel.ForEach(files, parOpts, currentFile =&gt;

    {

      parOpts

         .CancellationToken.ThrowIfCancellationRequested();

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

      string filename = Path.GetFileName(currentFile);

      Dispatcher?.Invoke(() =&gt;

      {

        this.Title =

          $&quot;Processing {filename}

             on thread {Thread.CurrentThread.ManagedThreadId}&quot;;

      });

      using (Bitmap bitmap = new Bitmap(currentFile))

      {

        bitmap.RotateFlip(RotateFlipType.Rotate180FlipNone);

        bitmap.Save(Path.Combine(outputDirectory, filename));

      }

    });

    Dispatcher?.Invoke(()=&gt;this.Title = &quot;Done!&quot;);

  }

  catch (OperationCanceledException ex)

  {

    Dispatcher?.Invoke(()=&gt;this.Title = ex.Message);

  }

}

Обратите внимание, что в начале метода конфигурируется объект ParallelOptions с установкой его свойства CancellationToken для применения маркера CancellationTokenSource. Кроме того, этот объект ParallelOptions передается во втором параметре методу Parallel.ForEach().

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

Обеспечение параллелизма задач с помощью класса Parallel

В дополнение к обеспечению параллелизма данных библиотека TPL также может использоваться для запуска любого количества асинхронных задач с помощью метода Parallel.Invoke(). Такой подход немного проще, чем применение делегатов или типов из пространства имен System.Threading, но если нужна более высокая степень контроля над выполняемыми задачами, тогда следует отказаться от использования Parallel.Invoke() и напрямую работать с классом Task, как делалось в предыдущем примере.

Чтобы взглянуть на параллелизм задач в действии, создайте новый проект консольного приложения по имени MyEBookReader и импортируйте в начале файла Program.cs пространства имен System.Threading, System.Text, System.Threading.Tasks, System.Linq и System.Net (пример является модификацией полезного примера из документации по .NET Core). Здесь мы будем извлекать публично доступную электронную книгу из сайта проекта Гутенберга (www.gutenberg.org) и затем параллельно выполнять набор длительных задач. Книга загружается в методе GetBook(), показанном ниже:

Перейти на страницу:
Комментариев (0)