Про курс
Асинхронний підхід до програмування дозволяє створювати код, виконання якого не буде блокувати виконання іншого коду. Завдяки такому підходу, наприклад, одночасно може бути виконано багато різних задач або можна розділити виконання однієї великої задачі на частини, що можуть бути виконані не послідовно, одна за одною, а одночасно.
Даний курс знайомить з підходами до асинхронного програмування в мові C#. Ви познайомитесь із засобами асинхронного та паралельного програмування, прикладами застосування цих підходів, з тим, що поєднує та відокремлює ці підходи до розробки. На курсі ви познайомитесь із шаблоном асинхронного програмування TAP (Task-based Asynchronous Pattern), порівняєте його з шаблонами APM та EAP. Також ви розберетесь у тому, чим є ключові слова async/await, розглянете їх технічну реалізацію, щоб краще розуміти, як працює ваш асинхронний код. Далі ви розглянете, що таке Thread та ThreadPool та як вони приймають участь у виконанні асинхронного коду, налаштування продовження задачі (TaskContinuation), планувальник задач (TaskScheduler) та контекст синхронізації, приклади роботи з великою кількістю задач, теорію блокування та синхронізації в багатопоточному середовищі та реалізацію цих засобів в .NET (як-от монітор, семафор, м’ютекс та інші).
Окремо на курсі розглядаються потокобезпечні колекції, їх призначення та будова, що таке розподілене програмування, види багатозадачності - витискальна та не витискальна. Ви познайомитесь з різними засобами класу Parallel та методами PLINQ, розглянете різні шаблони паралельної та асинхронної обробки даних.
Цей курс підійде як новачкам у програмуванні, так і досвідченим .NET розробникам, які хочуть покращити свої знання із асинхронного та паралельного програмування в C#. Для розуміння розглянутих у курсі тем знадобиться знання мови C# на рівні C# Поглиблений.
Цей курс входить до спеціальності:
Попередні Вимоги
- C#
- LINQ
- VisualStudio
Ви навчитеся
- Писати асинхронний код.
- Краще розуміти, як працюють ключові слова async/await.
- Розібратись, як найбільш оптимально створювати, стартувати та очікувати задачі.
- Обрати найбільш відповідні засоби синхронізації та блокування ресурсів.
- Дізнатись, які засоби паралелізації існують в C# та в яких випадках їх краще використовувати.
- Краще розуміти, які проблеми можуть вирішити паралельне та асинхронне програмування.
- Навчитись використовувати шаблони асинхронного та паралельного програмування.
- 5 год 52 хв
- 30.05.2024
- 8 з 8
- 05.06.2024
- українська
Що входить до курсу
×
Ви дійсно бажаєте відкрити доступ до тестування за курсом C# Асинхронне програмування на 40 днів?
Це перший урок курсу, метою якого є ознайомлення із основною термінологією, сферами використання та засобами асинхронного програмування. Важливою частиною цього та наступних уроків є практичні приклади застосування методів асинхронного програмування для розв’язання різних задач, тож студенту бажано встановити одну з IDE, що підтримують синтаксис С#.
Метою уроку є ознайомлення з шаблоном асинхронного програмування TAP (Task-based Asynchronous Pattern), порівняння його з вже розглянутими шаблонами APM та EAP.
Також під час заняття ви згадаєте, чим паралелізм відрізняється від конкурентності та які засоби для них містить TPL. Детально розглянемо класи Task/Task<TResult>, після чого повторимо, чим reference-типи відрізняються від value-типів та познайомимось із ValueTask/ValueTask<TResult>. Ми поговоримо про шаблони Абстрактна Фабрика та Фабричний метод, аби краще зрозуміти, що таке TaskFactory/TaskFactory<TResult> та як нею користуватись. Закінчивши із плануванням задач, розглянемо їх скасування (Cancellation) та продовження (TaskContinuation).
Метою уроку є розібратись у тому, чим є ключові слова async/await, розглянути їх технічну реалізацію, щоб краще розуміти, як працює ваш асинхронний код. Освіжимо в пам’яті теоретичні знання про скінчений автомат (state machine) та розглянемо приклад, згенерований компілятором. Також ми познайомимось з типами, які можуть повертати асинхронні методи та розберемо на прикладах, як та коли ними варто користуватись. Познайомимось з контекстом виконання та контекстом синхронізації, глянемо, як вони використовуються в асинхронному скінченому автоматі.
Під час цього уроку ми продовжимо розбиратися, як та завдяки чому працює вже розглянутий нами асинхронний скінчений автомат. Також ми згадаємо, що таке Thread та ThreadPool та як вони беруть участь у виконанні асинхронного коду. Поговоримо про налаштування продовження задачі (TaskContinuation), планувальник задач (TaskScheduler) та контекст синхронізації, розглянемо приклади роботи з великою кількістю задач.
Метою цього заняття є зрозуміти, в яких випадках виникає deadlock та як його можна уникнути. Також ми згадаємо теорію блокування та синхронізації в багатопоточному середовищі, розглянемо реалізацію цих засобів в .NET (як-от монітор, семафор, м’ютекс та інші). Також ми згадаємо, які помилки ми вже бачили, викликаючи асинхронний код, та як такі помилки можна обробити.
Метою цього уроку є знайомство з потокобезпечними колекціями, їх призначенням та будовою.
В ході уроку ми повторимо теорію про колекції, розглянемо, як побудовані базові колекції, що ховається за ключовим словом foreach та нащо нам потрібен ітератор. Також ми познайомимось з потокобезпечними колекціями з простору імен System.Collections.Concurrent та розберемося, як вони працюють. Крім того, розглянемо тип Channel, який можна використовувати в асинхронному коді без додаткових засобів синхронізації.
Метою цього уроку є підсумування всього, що ми знаємо про створення та виконання задач, а також більш детальне ознайомлення з планувальником задач.
В ході уроку ми поговоримо про основні методи та властивості планувальників задач, познайомимось з існуючими реалізаціями і тим, як вони планують та виконують роботу. Розберемося, чим є задачі верхнього рівня, дочірні та вкладені задачі. Згадаємо, чим є контекст синхронізації та як він може використовуватись планувальником задач. Також напишемо власний планувальник задач, щоб на практиці підсумувати всі отримані знання.
Метою цього уроку є ознайомлення з підходами до паралельного програмування, які задачі можна вирішити за допомогою цих підходів та де їх використовувати недоцільно.
В ході уроку ми згадаємо, чим конкурентність відрізняється від паралелізму, дізнаємось, що таке розподілене програмування. Також поговоримо про види багатозадачності - витискальну та не витискальну. Познайомимось з різними засобами класу Parallel та методами PLINQ. Наприкінці уроку розглянемо різні шаблони паралельної та асинхронної обробки даних та виконання операцій, які ви зможете використовувати для розв’язання задач.