Проектирование больших систем на С++ — различия между версиями

Материал из Кафедра математической кибернетики
Перейти к: навигация, поиск
 
(не показаны 395 промежуточные версии 4 участников)
Строка 1: Строка 1:
{{DISPLAYTITLE:Проектирование больших систем на С++}}
+
[[Категория:Спецкурсы кафедры МК]]
Курс по магистерской программе Дискретные управляющие системы и их приложения. Занятия проводит [[Участник:KonovodovV|Коноводов В.А.]]
+
[[Категория:Лекционные курсы кафедры МК]]
 +
[[Категория:Магистерская программа Дискретные управляющие системы и их приложения]]
  
Занятия в осеннем семестре 2018 г. завершены.
+
Занятия проводятся по вторникам шестой парой (в 18:00) '''ДИСТАНЦИОННО''', ссылка на видеоконференцию публикуется в [https://t.me/+OlbcW8JHJMdjOGZi чате в Telegram]
  
В курсе рассматриваются темы, востребованные в промышленном программировании на языке C++. Разбираются вопросы, связанные с обобщенным программированием, интеллектуальными указателями, исключениями, паттернами проектирования, тестированием и отладкой кода, и др. Отдельно разбираются возможности современного языка С++, введенные в стандартах C++11/14/17: вывод типов, семантика перемещения, rvalue-ссылки, поддержка многопоточности, лямбда-выражения и др.  
+
Курс по магистерской программе Дискретные управляющие системы и их приложения. Занятия проводит [[Участник:ZhukovVV|Владимир Владимирович Жуков.]]
 +
 
 +
В курсе рассматриваются темы, востребованные в промышленном программировании на языке C++. Разбираются вопросы, связанные с метапрограммированием, умными указателями, исключениями, паттернами проектирования, тестированием, отладкой кода и др. Отдельно разбираются возможности современного языка С++, введенные в стандартах C++11/14/17/20: вывод типов, семантика перемещения, rvalue-ссылки, поддержка многопоточности, лямбда-выражения и др.  
  
 
В задачи курса входят актуализация студентами знаний языка С++ и ознакомление с современными принципами проектирования больших систем с использованием языка C++.  
 
В задачи курса входят актуализация студентами знаний языка С++ и ознакомление с современными принципами проектирования больших систем с использованием языка C++.  
 +
 
На занятиях предполагается разбор примеров использования конструкций языка и применения рассматриваемых методов проектирования, а также проведение промежуточных небольших тестов-контрольных.
 
На занятиях предполагается разбор примеров использования конструкций языка и применения рассматриваемых методов проектирования, а также проведение промежуточных небольших тестов-контрольных.
  
'''Таблица результатов''' (задачи, тесты на занятиях и т.п.) доступна по [https://goo.gl/Br2zAd ссылке].
+
[[Media: Pbscpp.pdf|Программа курса (pdf)]]
  
==Задания по курсу==
+
== Занятия в 2025 г. ==
===Задание 1===
+
Срок сдачи задания: 31 октября 2018 г. 23:59.
+
* [[Media:Pbscpp_problem1_2018.pdf|Условие]].
+
* [https://github.com/konovodov/cmc_msu_cpp_course/tree/master/problem1 Ссылка на код].
+
  
===Задание 2===
+
* [https://docs.google.com/spreadsheets/d/1qxbn-J2YLaPhsL-msDzq8Od13aR1j1lp_JGvFNtwnmk/edit?usp=sharing Таблица результатов]
Срок сдачи задания: 25 ноября 2018 г. 23:59.
+
* [https://t.me/+OlbcW8JHJMdjOGZi Чат в Telegram]
* [[Media:Pbscpp_problem2_2018.pdf|Условие]].
+
* Первое занятие состоится 2 сентября в 18:00 в ауд. 504.
 +
* Следующие задания проводятся дистанционно.
 +
* Досрочный экзамен: DD.12.2024 HH:MM (ауд. N1)
 +
* Основной экзамен: DD.01.2025 HH:MM (ауд. N2)
  
===Задание 3===
+
== Экзамен ==
TBA
+
Экзамен по курсу письменный. Максимальная сумма баллов за экзаменационную работу – 54.
  
== Содержание курса ==
+
* Оценка '''отлично''': не менее 40 баллов
'''Занятие 1.''' Вводный тест. Особенности языка C++11. Вывод типов. Ключевые слова decltype и auto.
+
* Оценка '''хорошо''': не менее 30 и не более 39 баллов
 +
* Оценка '''удовлетворительно''': не менее 20 и не более 29 баллов
  
'''Занятие 2.''' Ключевые слова override и final. Удаленные функции. Псевдонимы. Перечисления с областью видимости. Объекты и функции constexpr.
+
[[Media: Pbs_exam_example_2024.pdf|Пример экзаменационного варианта (pdf)]]
  
* [[Media: Pbscpp_task_2018_2.pdf|Задачи к занятию 2]]. ''[c 29.09 решения задач больше не принимаются]''
+
== Содержание курса ==
* [[Media: Lection_pbscpp_1_2_2018.pdf|Лекция 1-2]].
+
'''Занятие 1.''' Введение. Организационные вопросы. Вводный тест. Стиль кодирования.
 +
* [https://disk.yandex.ru/i/RS2x0iZmCY-NDQ Лекция 1]
 +
* [https://github.com/catboost/catboost/blob/master/CPP_STYLE_GUIDE.md Yandex C++ Style Guide].
 +
* [https://google.github.io/styleguide/cppguide.html Google C++ Style Guide]
 +
* Книги Скотта Мейерса на английском языке можно найти на [https://aovst.cs.msu.ru/ сайте практикума 318 группы]
 +
* TODO на 2026 год: добавить в слайды контент на 20 минут. Можно, например, про STL напомнить.
  
'''Занятие 3.''' Функции constexpr, variadic templates, std::tuple, лямбда-выражения, функторы.
+
'''Занятие 2.''' Категории выражений в C++. Вывод типов параметров шаблонов и auto. Некоторые особенности C++11 (универсальная инициализация, константные выражения, шаблоны с переменным числом аргументов и др.).
 +
* [https://disk.yandex.ru/i/7-DPnwcUrkONYA Лекция 2]
 +
* [https://disk.yandex.ru/d/L19s661Y8JrTyA Задание 1] (результаты см. в таблице успеваемости в отдельной вкладке)
  
* [[Media: Pbscpp_task_2018_3.pdf|Задачи к занятию 3]].  ''[c 28.09 решение задачи больше не принимается]''
+
'''Занятие 3.''' Функциональное программирование в C++. Хеш-таблицы. Новые возможности C++17 (инициализация в условных выражениях, std::optional, std::string_view).
* [[Media: Lection_pbscpp_3_2018_part1.pdf ‎|Лекция 3]].
+
* [https://disk.yandex.ru/i/i3EFnpjuyybS6w Лекция 3]
 +
* [https://disk.yandex.ru/i/_p8FUMICX1XnwQ Запись лекции]
  
'''Занятие 4.''' Связыватели. move-семантика.
+
'''Занятие 4.''' Семантика перемещения в C++.
* [[Media: Pbscpp_task_2018_4.pdf|Задачи к занятию 4]].  ''[с 05.10 решение задачи больше не принимается]''
+
* [https://disk.yandex.ru/i/fC2fUMpHDZ6IOA Лекция 4]
 +
* [https://disk.yandex.ru/i/hflbAyVsoTVwBA Запись лекции]
 +
* TODO на 2026 год: устранить повторения информации в лекциях 2-4. Скукота получается, если одно и то же повторяется. Как будто лекции Машечкина какие-то.
  
'''Занятие 5.''' Типы ссылок. Прямая передача. Проблемы перегрузки универсальных ссылок. Перемещающие операции.
+
'''Занятие 5.''' Операторы new и delete. Умные указатели. Управление владением памяти.
* [[Media: Lection_pbscpp_4_2018.pdf ‎|Лекция 5]].
+
* [https://disk.yandex.ru/i/VIoQHePuAQd7ow Лекция 5]
 +
* [https://disk.yandex.ru/d/eFyL3Xl08USEAg Запись лекции]
  
'''Занятие 6.''' Выделение и распределение памяти. Умные указатели unique_ptr и shared_ptr.
+
'''Занятие 6.''' Идиомы в C++. Идиома CRTP. Шаблон std::enable_shared_from_this. Умный указатель boost::intrusive_ptr. Идиома PImpl. Идиома Type Erasure.
* [[Media: Lection_pbscpp_6_2018.pdf ‎|Лекция 6]].
+
* [https://disk.yandex.ru/i/AVYcaBknBY2qMA Лекция 6]
* [[Media: Pbscpp_task_2018_6.pdf|Задачи к занятию 6]]. ''[с 19.10 решение задачи больше не принимается]''
+
* [https://disk.yandex.ru/i/RGy1wEp6qVfICg Запись лекции]
 +
* TODO на 2026 год: добавить хрона на 20 минут
  
'''Занятие 7.''' Указатель weak_ptr. enable_shared_from_this как пример CRTP. Идиома PImpl. Паттерн проектирования Bridge.
+
'''Занятие 7.''' Идиома PImpl. Паттерны проектирования Bridge, Command, Strategy, Singleton.
* [[Media: Lection_pbscpp_7_2018.pdf ‎|Лекция 7]].
+
* [https://disk.yandex.ru/i/EUs0mYjw8IVKeg Лекция 7 (deprecated)]
* [[Media: Pbscpp_task_2018_7.pdf|Задачи к занятию 7]]. ''[с 01.11 решение задачи больше не принимается]''
+
* [https://mks2.cs.msu.ru/root/pbs_examples_2025 Репозиторий, где пишем код на занятиях]
  
'''Занятие 8.''' Паттерны проектирования Command, Singleton, Strategy, Decorator, Observer, Abstract factory.
+
'''Занятие 8.''' Создание объектов с помощью фабрик. Паттерны проектирования Decorator и Visitor.  
* [[Media: Lection_pbscpp_8_2018.pdf ‎|Лекция 8]].
+
* [https://disk.yandex.ru/i/5-9XGr4aQR9C2w Лекция 8 (deprecated)]
  
'''Занятие 9.''' Паттерн Visitor. Идиома Type Erasure. Правило SFINAE. Диспетчеризация дескрипторов.
+
'''Занятие 9.''' Идиома TypeErasure. Решение проблем перегрузки универсальных ссылок. Диспетчеризация дескрипторов. Правило SFINAE.
* [[Media: Lection_pbscpp_9_2018.pdf ‎|Лекция 9]].
+
* [https://disk.yandex.ru/i/6Ggf49W6ABX9Ag Лекция 9 (deprecated)]
* [[Media: Pbscpp_task_2018_9.pdf|Задачи к занятию 9]].  ''[с 08.11 решение задачи больше не принимается]''
+
  
'''Занятие 10.''' Шаблонное метапрограммирование. X-macro. Исключения. ValueOrException.
+
'''Занятие 10.''' Обработка исключений. Гарантии безопасности исключений. Неопределенное поведение.
* [[Media: Lection_pbscpp_10_2018.pdf ‎|Лекция 10]].
+
* [https://disk.yandex.ru/i/A0z1X7NJZLPNFQ Лекция 10 (deprecated)]
  
'''Занятие 11.''' Гарантии безопасности исключений и noexcept. Основные подходы к тестированию систем. Unit-тесты через google testing framework.
+
'''Занятие 11.''' Тестирование кода, unit-тестирование, устранение зависимостей. Google C++ Testing Framework.  
* [[Media: Lection_pbscpp_11_2018.pdf ‎|Лекция 11]].
+
* [https://disk.yandex.ru/i/VX2GqMOB9t76wA Лекция 11 (deprecated)]
 +
* [http://google.github.io/googletest/ Документация по googletest]
  
'''Занятие 12.''' Mock-объекты в тестировании и gmock. Отладка кода. Инструменты strace и gdb.  
+
'''Занятие 12.''' Отладка и дебаг кода. Оптимизация программ на C++. Строки.
* [[Media: Lection_pbscpp_12_2018.pdf ‎|Лекция 12]].
+
* [https://disk.yandex.ru/i/gzYOfpC0JfJPJw Лекция 12 (deprecated)]
* [https://github.com/konovodov/cmc_msu_cpp_course/tree/master/testing Ссылка на код про тесты с занятия].
+
  
'''Занятие 13.''' Многопоточное программирование с использованием std::thread. Примитивы синхронизации. Потокобезопасность.  
+
'''Занятие 13.''' Оптимизация алгоритмов, функций, памяти. Плотная упаковка полей. Бинарная сериализация данных. Protobuf.
* [[Media: Lection_pbscpp_13_2018.pdf ‎|Лекция 13]].
+
* [https://disk.yandex.ru/i/A39zehIlyOn3qg Лекция 13 (deprecated)]
  
== Программа курса ==
+
'''Занятие 14.''' Новые стандарты языка C++20 и C++23. Корутины, концепты, ranges library.
[[Media: Pbscpp_content2018.pdf|Программа курса (pdf)]]
+
* [https://disk.yandex.ru/d/8efRlJsZ9ZFA2g Презентации докладов (deprecated)]
  
 
== Литература ==
 
== Литература ==
 +
===Основная===
 
* С. Мейерс, Эффективный и современный С++: 42 рекомендации по использованию C++11 и C++14, изд. Вильямс, М.: 2017 г.
 
* С. Мейерс, Эффективный и современный С++: 42 рекомендации по использованию C++11 и C++14, изд. Вильямс, М.: 2017 г.
 +
* Ф. Пикус, Идиомы и паттерны проектирования в современном C++. ДМК Пресс, 2019 г.
 +
* CppCoreGuidelines (ред. Б. Страуструп, Г. Саттер) https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines
 +
* Курт Гантерот: Оптимизация программ на C++. Проверенные методы повышения производительности. М.:Диалектика, 2017 г.
 +
 +
===Дополнительная===
 +
* Klaus Iglberger. C++ Software Design: Design Principles and Patterns for High-Quality Software. O'Reilly Media; 1st edition. 2022.
 
* Anthony Williams. C++ Concurrency in Action: Practical Multithreading.  
 
* Anthony Williams. C++ Concurrency in Action: Practical Multithreading.  
 
* А. Александреску, Современное проектирование на C++, изд. Вильямс, М.: 2017 г.
 
* А. Александреску, Современное проектирование на C++, изд. Вильямс, М.: 2017 г.
Строка 82: Строка 104:
 
* Б. Страуструп, Язык программирования С++, 4-е издание.
 
* Б. Страуструп, Язык программирования С++, 4-е издание.
 
* Б. Страуструп, Программирование. Принципы и практика использования C++.
 
* Б. Страуструп, Программирование. Принципы и практика использования C++.
* Б. Страуструп, Дизайн и эволюция языка С++.
+
* Вандевурд Д., Джосаттис Н. Шаблоны C++. Справочник разработчика.
* D. Abrahams, A. Gurtovoy C++ Template Metaprogramming.
+
* Курс [https://academy.yandex.ru/handbook/cpp Основы C++] от Академии Яндекса.
 
+
* [http://google.github.io/googletest/ Документация] по Google Test.
 
+
* [https://developers.google.com/protocol-buffers/docs/overview?hl=en Документация] protobuf.
[[Категория:Лекционные курсы кафедры МК]]
+
* [https://github.com/catboost/catboost/blob/master/CPP_STYLE_GUIDE.md Yandex C++ Style Guide].
[[Категория:Магистерская программа Дискретные управляющие системы и их приложения]]
+
* [https://google.github.io/styleguide/cppguide.html Google C++ Style Guide].

Текущая версия на 21:10, 7 октября 2025


Занятия проводятся по вторникам шестой парой (в 18:00) ДИСТАНЦИОННО, ссылка на видеоконференцию публикуется в чате в Telegram

Курс по магистерской программе Дискретные управляющие системы и их приложения. Занятия проводит Владимир Владимирович Жуков.

В курсе рассматриваются темы, востребованные в промышленном программировании на языке C++. Разбираются вопросы, связанные с метапрограммированием, умными указателями, исключениями, паттернами проектирования, тестированием, отладкой кода и др. Отдельно разбираются возможности современного языка С++, введенные в стандартах C++11/14/17/20: вывод типов, семантика перемещения, rvalue-ссылки, поддержка многопоточности, лямбда-выражения и др.

В задачи курса входят актуализация студентами знаний языка С++ и ознакомление с современными принципами проектирования больших систем с использованием языка C++.

На занятиях предполагается разбор примеров использования конструкций языка и применения рассматриваемых методов проектирования, а также проведение промежуточных небольших тестов-контрольных.

Программа курса (pdf)

Занятия в 2025 г.

  • Таблица результатов
  • Чат в Telegram
  • Первое занятие состоится 2 сентября в 18:00 в ауд. 504.
  • Следующие задания проводятся дистанционно.
  • Досрочный экзамен: DD.12.2024 HH:MM (ауд. N1)
  • Основной экзамен: DD.01.2025 HH:MM (ауд. N2)

Экзамен

Экзамен по курсу письменный. Максимальная сумма баллов за экзаменационную работу – 54.

  • Оценка отлично: не менее 40 баллов
  • Оценка хорошо: не менее 30 и не более 39 баллов
  • Оценка удовлетворительно: не менее 20 и не более 29 баллов

Пример экзаменационного варианта (pdf)

Содержание курса

Занятие 1. Введение. Организационные вопросы. Вводный тест. Стиль кодирования.

Занятие 2. Категории выражений в C++. Вывод типов параметров шаблонов и auto. Некоторые особенности C++11 (универсальная инициализация, константные выражения, шаблоны с переменным числом аргументов и др.).

Занятие 3. Функциональное программирование в C++. Хеш-таблицы. Новые возможности C++17 (инициализация в условных выражениях, std::optional, std::string_view).

Занятие 4. Семантика перемещения в C++.

  • Лекция 4
  • Запись лекции
  • TODO на 2026 год: устранить повторения информации в лекциях 2-4. Скукота получается, если одно и то же повторяется. Как будто лекции Машечкина какие-то.

Занятие 5. Операторы new и delete. Умные указатели. Управление владением памяти.

Занятие 6. Идиомы в C++. Идиома CRTP. Шаблон std::enable_shared_from_this. Умный указатель boost::intrusive_ptr. Идиома PImpl. Идиома Type Erasure.

Занятие 7. Идиома PImpl. Паттерны проектирования Bridge, Command, Strategy, Singleton.

Занятие 8. Создание объектов с помощью фабрик. Паттерны проектирования Decorator и Visitor.

Занятие 9. Идиома TypeErasure. Решение проблем перегрузки универсальных ссылок. Диспетчеризация дескрипторов. Правило SFINAE.

Занятие 10. Обработка исключений. Гарантии безопасности исключений. Неопределенное поведение.

Занятие 11. Тестирование кода, unit-тестирование, устранение зависимостей. Google C++ Testing Framework.

Занятие 12. Отладка и дебаг кода. Оптимизация программ на C++. Строки.

Занятие 13. Оптимизация алгоритмов, функций, памяти. Плотная упаковка полей. Бинарная сериализация данных. Protobuf.

Занятие 14. Новые стандарты языка C++20 и C++23. Корутины, концепты, ranges library.

Литература

Основная

  • С. Мейерс, Эффективный и современный С++: 42 рекомендации по использованию C++11 и C++14, изд. Вильямс, М.: 2017 г.
  • Ф. Пикус, Идиомы и паттерны проектирования в современном C++. ДМК Пресс, 2019 г.
  • CppCoreGuidelines (ред. Б. Страуструп, Г. Саттер) https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines
  • Курт Гантерот: Оптимизация программ на C++. Проверенные методы повышения производительности. М.:Диалектика, 2017 г.

Дополнительная

  • Klaus Iglberger. C++ Software Design: Design Principles and Patterns for High-Quality Software. O'Reilly Media; 1st edition. 2022.
  • Anthony Williams. C++ Concurrency in Action: Practical Multithreading.
  • А. Александреску, Современное проектирование на C++, изд. Вильямс, М.: 2017 г.
  • Э.Гамма, Р.Хелм, Р.Джонсон, Дж. Влиссидес, Приемы объектно-ориентированного проектирования.
  • Г. Саттер, А. Александреску, Стандарты программирования на С++. 101 правило и рекомендация.
  • Б. Страуструп, Язык программирования С++, 4-е издание.
  • Б. Страуструп, Программирование. Принципы и практика использования C++.
  • Вандевурд Д., Джосаттис Н. Шаблоны C++. Справочник разработчика.
  • Курс Основы C++ от Академии Яндекса.
  • Документация по Google Test.
  • Документация protobuf.
  • Yandex C++ Style Guide.
  • Google C++ Style Guide.