Факультативный спецкурс «Программирование на C++»
Антон Дедов
Дмитрий Иртегов
отдельно благодарим за участие в обсуждении Каменского Никиту и преподавателя ФИТ В. Рылова
Цели и задачи
Цели курса:
- Ознакомление с культурой и принятыми практиками программирования в сообществе C++, знакомство с современным состоянием языка.
- Получение знаний, необходимых для создания более качественного и безопасного кода.
- Формирование сознательного отношения к использованию тех или иных средств языка, а не изучение «крутых» трюков.
Основные темы курса:
* проектирование классов, принципы объектно-ориентированного проектирования;
* использование стандартной библиотеки и ее признанных расширений;
* безопасность исключений и требования, которые это налагает на дизайн.
Содержание курса
Курс условно разбит на несколько модулей. Каждый модуль логически объединяет смежные темы.
Модули содержат специфические примеры кода, которые, демонстрируют распространенные техники написания программ на C++, а так же использование стандартной библиотеки.
Список модулей:
- Введение в язык
- Объектно-ориентированное программирование
- Исключения и обработка ошибок
- Шаблоны
- Введение в стандартную библиотеку C++
Модули естественным образом разбиваются на части, минимальная единица – лекция. Лекции разных модулей могут перемежаться для облегчения понимания смежных тем из других модулей.
Введение в язык
Лекция 1
- Объявления и определения.
- Встроенные типы данных. Переменные; квалификаторы const.
- Указатели. Массивы. Строковые литералы. Ссылки.
- Области видимости имен.
- Структуры как средство группировки данных.
Лекция 2
- Функции.
Аргументы функций. Объявление и определение. Перегрузка и поиск.
- Правило оформления заголовочных файлов.
- Классы, структура классов.
Конструкторы и деструкторы. Ограничение доступа. Специальные методы. Константность.
Лекция 3
- Объекты.
Конструирование. Временные объекты. Расположение объектов в памяти. Время жизни объектов.
- Пространства имен.
Определение. Объявление членов пространств имен. Безымянные пространства имен. Using директивы и объявления. Псевдонимы. Композиция и отбор. Поиск имен.
Лекция 4
- Исключения.
Жизненный цикл исключения. Исключения и конструкторы. И деструкторы. Функции terminate, unexpected и uncaught_exception. Стандартные исключения. Группировка исключений. RAII.
Советы по проектированию классов
Лекция 5
- Проектирование классов исходя из их назначения.
Классы значений. Базовые классы. Классы исключений.
- Избегайте наследования классов не предназначенных для этого.
- Делайте нетерминальные классы абстрактными.
- Клонирование как альтернатива копированию.
Принципы объектно-ориентированного проектирования
Лекция 6
- Признаки гниения дизайна.
- Ценности гибкого подхода к разработке ПО.
- Принцип персональной ответственности.
- Принцип «открытия-закрытия».
- Принцип подстановки Лисковой.
Лекция 7
- Принцип инверсии зависимостей.
- Принцип отделения интерфейса.
- Пример «загнивающего» дизайна.
Исключения и обработка ошибок
Лекция 8
- Что является ошибкой?
- Стратегия обработки ошибок.
Преимущества использования исключений. Ситуации когда использование исключений не дает преимуществ.
- Использование утверждений.
Когда следует использовать утверждения. Мертвые программы не лгут.
Лекция 9
- Разработка кода безопасного с точки зрения исключений.
- Гарантии безопасности исключений.
Шаблоны
Лекция 10
- Шаблоны.
Зачем нужны шаблоны? Определение шаблона. Инстанцирование. Компиляция шаблона.
- Шаблоны функций.
Вывод аргументов шаблона. Перегрузка шаблонов функций.
Лекция 11
- Шаблоны классов.
Определение шаблонного класса. Имена шаблонных классов. Аргументы по умолчанию. Аргументы не являющиеся типами.
- Полная и частичная специализация шаблонов классов.
- Использование шаблонов классов.
Стандартная библиотека
Лекция 12
- Состав и назначение стандартной библиотеки.
- Контейнерные шаблонные классы.
Последовательности и ассоциативные контейнеры. Назначение и различие стандартных контейнеров. Критерии выбора контейнера.
Лекция 13
- Стандартные алгоритмы.
Описание наиболее популярных алгоритмов STL: find, for_each, copy, transform. Что делает алгоритм remove. Идиома erase(remove).
- Итераторы.
Что такое стандартный итератор STL. Типы итераторов. Как создавать итераторы совместимые со стандартными.
Литература
Список литературы составлен в алфавитном порядке.
- Андрей Александреску. Современное проектирование на С++. Обобщенное программирование и прикладные шаблоны проектирования. // 2002
- Гради Буч. Объектно-ориентированный анализ и проектирование. С примерами приложений на C++. // 2000; В библиотеке НГУ
- Дэвид Вандевурд, Николаи М. Джосаттис. Шаблоны C++. Справочник разработчика. // 2003; В библиотеке НГУ
- Эрих Гамма, Ричард Хелм, Ральф Джонсон, Джон Влиссидес. Приемы объектно-ориентированного проектирования. Паттерны проектирования. // 2001; В библиотеке НГУ
- Скотт Мейерс. Эффективное использование C++. 50 рекомендаций по улучшению ваших программ и проектов. // 2000 В библиотеке НГУ
- Скотт Мейерс. Наиболее эффективное использование C++. 35 новых рекомендаций по улучшению ваших программ и проектов. // 2000 В библиотеке НГУ
- Скотт Майерс. Эффективное использование STL. // 2002
- Герб Саттер. Решение сложных задач на C++. // 2002
- Герб Саттер. Новые сложные задачи на C++: 40 новых головоломных примеров с решениями. // 2005; В библиотеке НГУ
- Герб Саттер и Андрей Александреску. Стандарты программирования на C++: 101 правило и рекомендация. // 2005; В библиотеке НГУ
- Бьерн Страуструп. Язык программирования C++. // 2001; В библиотеке НГУ
- Бьерн Страуструп. Дизайн и эволюция языка C++. // 2000
- ISO/IEC 14882:1998(E), Programming Languages??? C++ (ISO and ANSI C++ standard).
- Robert C. Martin. Design Principles and Design Patterns. // objectmentor.com 2000
Полезные ссылки