Python [Павел Хошев] [Stepik] Многопоточный Python (2024)

Administrator
Команда форума
Premium
18 Дек 2018
8,846
35,876
113
#1
1715932688938-png.56395

Описание курса:
С этим курсом вы освоите многопоточное программирование и откроете для себя мир высокопроизводительных приложений! Курс предлагает хорошо структурированную теорию, практические задания, поддержку экспертов и доступ к сообществу.
Погрузитесь в учебу, примените полученные знания на практике и станьте востребованным специалистом, подтвердив свои навыки сертификатом.
Начните трансформацию своего кода и карьеры запишитесь на курс уже сегодня!

Цели курса:
Курс направлен на изучение и глубокое понимание многопоточности. Целью является обучение разработчиков созданию высокопроизводительных и эффективных многопоточных приложений, позволяющих максимально использовать ресурсы современных систем.

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

Что приобретут учащиеся после его успешного освоения:
После успешного завершения курса учащиеся приобретут навыки:
  • Разработки многопоточных приложений на Python;
  • Эффективного использования потоков и пулов потоков;
  • Оптимизации производительности программ;
  • Понимания и устранения проблем, связанных с многопоточностью.
  • И многое другое...
Особенности курса:
  • Практическая ориентированность: Курс сфокусирован на практических задачах, что помогает лучше усвоить материал.
  • Гибкость и доступность: Предлагается удобный формат обучения, подходящий как для новичков, так и для опытных разработчиков.
  • Поддержка сообщества и наставников: Учащиеся имеют доступ к помощи и поддержке со стороны преподавателей и сообщества.
  • Сертификация: Выдача сертификата по окончании курса, подтверждающего приобретенные навыки.
Что нужно будет делать:
Учащимся предстоит изучать теоретические материалы, выполнять практические задания, тестировать и оптимизировать многопоточные приложения и радоваться полученным навыкам.
Для кого этот курс:
Начинающие программисты, которые хотят углубить свои знания в Python и изучить многопоточное программирование для повышения своей квалификации и рыночной ценности. — Опытные разработчики, стремящиеся расширить свои компетенции и улучшить производительность существующих приложений через эффективное использование многопоточности. — Специалисты по анализу данных и искусственного интеллекта, для которых конкурентная обработка данных является ключом к ускорению вычислений и повышению эффективности алгоритмов. — Студенты технических специальностей, желающие углубить свои знания в современных методах программирования и подготовиться к будущей карьере в IT. — Веб-разработчики, ищущие способы улучшить отзывчивость и производительность своих приложений на стороне сервера. — Профессионалы в области IT, нуждающиеся в улучшении навыков работы с многопоточностью для решения специфических задач, например, в разработке игр или комплексных систем реального времени.
Программа курса:
Введение в многопоточность
  • Введение
  • Основные понятия
  • Что такое потоки
  • Что такое главный поток
  • Ожидание результата от потока
  • Ожидание выполнения потока
  • Имена потоков
  • Атрибуты потока
  • Хранение локальных данных потока
  • Атомарные операции
  • Как перезапустить поток
  • Блокирующие вызовы в потоках
  • Поток-таймер
  • Вспомогательные функции для работы с потоками
Работа с пулами потоков и Executors
  • Что такое пулы потоков
  • Создание пула потоков
  • Отправка задач в пул потоков с помощью submit() и map()
  • Получаем результаты из пула потоков
  • Жизненный цикл ThreadPoolExecutor
  • Что такое Executors
  • Ожидание завершения задач
  • Инициализация рабочих потоков
  • Завершение работы пула потоков
  • Количество потоков
  • Тестирование и оптимальное количество потоков
  • ThreadPoolExecutor vs AsyncIO
Подробнее о Futures
  • Что такое Futures
  • Объект Future
  • Методы Future
  • Жизненный цикл Future
  • Проверяем статус Future
  • Добавляем обратный вызов к Future
  • Получение исключений из Future
  • Всё об отмене Future
Управление потоками и синхронизация
  • Блокировка взаимного исключения. Объект Lock
  • Реентерабельная блокировка
  • Синхронизация по событиям (Event)
  • Синхронизация с условием (Condition)
  • Семафор в потоках
  • Как остановить все задачи
  • Остановить все задачи, если одна завершилась неудачей
  • Барьер в потоках (Barrier)
Advanced Locking - Продвинутое блокирование
  • Конкуренция за блокировку
  • Чередование блокировок
  • Разделение блокировок
  • Повторная попытка блокировки с откатом
  • Накладные расходы поточной блокировки
Практические применение и продвинутые техники
  • Последовательная и параллельная загрузка
  • Одновременная загрузка файлов с submit() и as_completed()
  • Обработка исключений во время выполнения задачи
Безопасность потоков
  • Потокобезопасный счетчик
  • Потокобезопасная печать
  • Потокобезопасное логирование
  • Потокобезопасный словарь
  • Потокобезопасный список
  • Потокобезопасная запись в файл
  • Непостоянные переменные
Создание и работа с пулом потоков в модуле multiprocessing
  • ThreadPoolExecutor vs ProcessPoolExecutor
  • Синхронное выполнение одиночной задачи
  • Асинхронное выполнение одиночной задачи
  • Синхронная обработка коллекций
  • Асинхронная обработка коллекций
  • Итеративная синхронная обработка задач
  • Итеративная синхронная обработка задач без сохранения порядка
  • Синхронная обработка задач с множеством аргументов
  • Асинхронная обработка задач с множеством аргументов
  • Какой метод выбрать?
  • Сравнение методов
  • Лучшие практики использования пула процессов
  • Распространенные ошибки

Скачать [Павел Хошев] [Stepik] Многопоточный Python (2024)



Чтобы скачать курс, новым пользователям, необходимо Пройти Регистрацию
Если у вас уже есть аккаунт Войти на Форум