Стенли Липпман - Язык программирования C++. Пятое издание
- Название:Язык программирования C++. Пятое издание
- Автор:
- Жанр:
- Издательство:Издательский дом Вильямс
- Год:2014
- Город:Москва
- ISBN:978-5-8459-1839-0
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Стенли Липпман - Язык программирования C++. Пятое издание краткое содержание
Вы держите в руках новое издание популярного и исчерпывающего бестселлера по языку программирования С++, которое было полностью пересмотрено и обновлено под
. Оно поможет вам быстро изучить язык и использовать его весьма эффективными и передовыми способами. В соответствии с самыми передовыми и современными методиками изложения материала авторы демонстрируют использование базового языка и его стандартной библиотеки для разработки эффективного, читабельного и мощного кода.
С самого начала этой книги читатель знакомится со стандартной библиотекой С++, ее самыми популярными функциями и средствами, что позволяет сразу же приступить к написанию полезных программ, еще не овладев всеми нюансами языка. Большинство примеров из книги было пересмотрено так, чтобы использовать новые средства языка и продемонстрировать их наилучшие способы применения. Эта книга — не только проверенное руководство для новичков в С++, она содержит также авторитетное обсуждение базовых концепций и методик языка С++ и является ценным ресурсом для опытных программистов, особенно желающих побыстрей узнать об усовершенствованиях С++11.
Стенли Б. Липпман Жози Лажойе Барбара Э. Му • Узнайте, как использовать новые средства языка С++11 и стандартной библиотеки для быстрого создания надежных программ, а также ознакомьтесь с высокоуровневым программированием
• Учитесь на примерах, в которых показаны передовые стили программирования и методики проектирования
• Изучите принципы и узнайте почему язык С++11 работает именно так
• Воспользуйтесь множеством перекрестных ссылок, способных помочь вам объединить взаимосвязанные концепции и проникнуть в суть
• Ознакомьтесь с современными методиками обучения и извлеките пользу из упражнений, в которых подчеркиваются ключевые моменты, позволяющие избежать проблем
• Освойте лучшие методики программирования и закрепите на практике изученный материал
Исходный код примеров можно загрузить с веб-страницы книги на сайте издательства по адресу: http://www.williamspublishing.com
Язык программирования C++. Пятое издание - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
// каждый контейнер имеет три элемента, инициализированных
// предоставленными инициализаторами
list authors = {"Milton", "Shakespeare", "Austen"};
vector articles = {"a", "an", "the"};
list list2(authors); // ok: типы совпадают
deque authList(authors); // ошибка: типы контейнеров
// не совпадают
vector words(articles); // ошибка: типы элементов не совпадают
// ok: преобразует элементы const char* в string
forward_list words(articles.begin(), articles.end());
При копировании содержимого одного контейнера в другой типы контейнеров и их элементов должны точно совпадать.
Конструктор, получающий два итератора, использует их для обозначения диапазона копируемых элементов. Как обычно, итераторы отмечают первый и следующий элемент после последнего копируемого. Размер нового контейнера будет совпадать с количеством элементов в диапазоне. Каждый элемент в новом контейнере инициализируется значением соответствующего элемента в диапазоне.
Поскольку итераторы обозначают диапазон, этот конструктор можно использовать для копирования части последовательности. С учетом того что itявляется итератором, обозначающим элемент в контейнере authors, можно написать следующее:
// копирует до, но не включая элемент, обозначенный итератором it
deque authList(authors.begin(), it);
По новому стандарту контейнер допускает списочную инициализацию (см. раздел 3.3.1):
// каждый контейнер имеет три элемента, инициализированных
// предоставленными инициализаторами
list authors = {"Milton", "Shakespeare", "Austen"};
vector articles = {"a", "an", "the"};
Это определяет значение каждого элемента в контейнере явно. Кроме контейнеров таких типов, как array, список инициализации неявно определяет также размер контейнера: у контейнера будет столько элементов, сколько инициализаторов в списке.
Кроме конструкторов, общих для последовательных и ассоциативных контейнеров, последовательные контейнеры (кроме массива) можно также инициализировать, указав их размера и (необязательного) инициализирующий элемент. Если его не предоставить, библиотека создает инициализирующее значение сама (см. раздел 3.3.1):
vector ivec(10, -1); // десять элементов типа int; значение -1
list svec(10, "hi!"); // десять строк; значение "hi!"
forward_list ivec(10); // десять элементов; значение 0
deque svec(10); // десять элементов; все пустые строки
Конструктор, получающий аргумент размера, можно также использовать, если элемент имеет встроенный тип или тип класса, у которого есть стандартный конструктор (см. раздел 9.2). Если у типа элемента нет стандартного конструктора, то наряду с размером следует определить явный инициализатор элемента.
Конструкторы, получающие размер, допустимы только для последовательных контейнеров; ассоциативные контейнеры их не поддерживают.
Подобно тому, как размер встроенного массива является частью его типа, размер библиотечного контейнера arrayтоже входит в состав его типа. Когда определяется массив, кроме типа элемента задается также размер контейнера:
array // тип: массив, содержащий 42 целых числа
array // тип: массив, содержащий 10 строк
Чтобы использовать контейнер array, следует указать тип элемента и его размер:
array::size_type i; // тип массива включает тип элемента
// и размер
array::size_type j; // ошибка: array - это не тип
Поскольку размер является частью типа массива, контейнер array не поддерживает обычные конструкторы контейнерных классов. Эти конструкторы, явно или неявно, определяют размер контейнера. В случае массива разрешение пользователям передавать аргумент размера было бы избыточно (в лучшем случае) и приводило бы к ошибкам.
Фиксированный характер размера массивов влияет также на поведение остальных конструкторов, действительно определяющих массив. В отличие от других контейнеров, созданный по умолчанию массив не пуст: количество его элементов соответствует размеру, а инициализированы они значением по умолчанию (см. раздел 2.2.1), как и элементы встроенного массива (см. раздел 3.5.1). При списочной инициализации массива количество инициализаторов не должно превышать размер массива. Если инициализаторов меньше, чем элементов массива, они используются для первых элементов, а все остальные инициализируются значением по умолчанию (см. раздел 3.3.1). В любом случае, если типом элемента является класс, то у него должен быть стандартный конструктор, обеспечивающий инициализацию значением по умолчанию:
array ia1; // десять целых чисел, инициализированных
// значением по умолчанию
array ia2 = {0,1,2,3,4,5,6,7,8,9}; // списочная инициализация
array ia3 = {42}; // ia3[0] содержит значение 42, остальные
// элементы - значение 0
Следует заметить, что хоть и нельзя копировать или присваивать объекты массивов встроенных типов (см. раздел 3.5.1), для контейнеров arrayтакого ограничения нет:
int digs[10] = {0,1,2,3,4,5,6,7,8,9};
int cpy[10] = digs; // ошибка: встроенные массивы не допускают
// копирования и присвоения
array digits = {0,1,2,3,4,5,6,7,8,9};
array copy = digits; // ok: если типы массивов совпадают
Как обычно, инициализирующий контейнер должен иметь тот же тип, что и создаваемый. Для контейнера arrayсовпадать должны тип элемента и размер, поскольку размер массива — часть его типа.
Упражнение 9.11. Приведите пример каждого из шести способов создания и инициализации контейнеров vector. Объясните, какие значения будет содержать каждый вектор.
Упражнение 9.12. Объясните различие между конструктором, получающим контейнер для копирования, и конструктором получающим два итератора.
Упражнение 9.13. Как инициализировать контейнер vectorиз контейнера listи контейнера vector? Напишите код для проверки ответов.
9.2.5. Присвоение и функция swap()
Связанные с присвоением операторы, перечисленные в табл. 9.4, воздействуют на весь контейнер. Оператор присвоения заменяет весь диапазон элементов в левом контейнере копиями элементов из правого:
Читать дальшеИнтервал:
Закладка: