Стенли Липпман - Язык программирования C++. Пятое издание
- Название:Язык программирования C++. Пятое издание
- Автор:
- Жанр:
- Издательство:Издательский дом Вильямс
- Год:2014
- Город:Москва
- ISBN:978-5-8459-1839-0
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Стенли Липпман - Язык программирования C++. Пятое издание краткое содержание
Вы держите в руках новое издание популярного и исчерпывающего бестселлера по языку программирования С++, которое было полностью пересмотрено и обновлено под
. Оно поможет вам быстро изучить язык и использовать его весьма эффективными и передовыми способами. В соответствии с самыми передовыми и современными методиками изложения материала авторы демонстрируют использование базового языка и его стандартной библиотеки для разработки эффективного, читабельного и мощного кода.
С самого начала этой книги читатель знакомится со стандартной библиотекой С++, ее самыми популярными функциями и средствами, что позволяет сразу же приступить к написанию полезных программ, еще не овладев всеми нюансами языка. Большинство примеров из книги было пересмотрено так, чтобы использовать новые средства языка и продемонстрировать их наилучшие способы применения. Эта книга — не только проверенное руководство для новичков в С++, она содержит также авторитетное обсуждение базовых концепций и методик языка С++ и является ценным ресурсом для опытных программистов, особенно желающих побыстрей узнать об усовершенствованиях С++11.
Стенли Б. Липпман Жози Лажойе Барбара Э. Му • Узнайте, как использовать новые средства языка С++11 и стандартной библиотеки для быстрого создания надежных программ, а также ознакомьтесь с высокоуровневым программированием
• Учитесь на примерах, в которых показаны передовые стили программирования и методики проектирования
• Изучите принципы и узнайте почему язык С++11 работает именно так
• Воспользуйтесь множеством перекрестных ссылок, способных помочь вам объединить взаимосвязанные концепции и проникнуть в суть
• Ознакомьтесь с современными методиками обучения и извлеките пользу из упражнений, в которых подчеркиваются ключевые моменты, позволяющие избежать проблем
• Освойте лучшие методики программирования и закрепите на практике изученный материал
Исходный код примеров можно загрузить с веб-страницы книги на сайте издательства по адресу: http://www.williamspublishing.com
Язык программирования C++. Пятое издание - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
bool compareIsbn(const Sales_data &lhs, const Sales_data &rhs) {
return lhs.isbn() < rhs.isbn();
}
Чтобы использовать собственный оператор, следует определить контейнер multisetс двумя типами: типом ключа Sales_dataи типом сравнения, являющимся типом указателя на функцию (см. раздел 6.7), способным указывать на функцию compareIsbn(). Когда определяют объекты этого типа, предоставляют указатель на функцию, которую предстоит использовать. В данном случае предоставляется указатель на функцию compareIsbn():
// в программе может быть несколько транзакций с тем же ISBN
// элементы bookstore упорядочены по ISBN
multiset
bookstore(compareIsbn);
Здесь для определения типа оператора используется спецификатор decltype. При использовании спецификатора decltypeдля получения указателя на функцию следует добавить символ *для обозначения использования указателя на заданный тип функции (см. раздел 6.7). Инициализацию bookstoreосуществляет функция compareIsbn(). Это означает, что при добавлении элементов в bookstoreони будут упорядочены при вызове функции compareIsbn(). Таким образом, элементы bookstoreбудут упорядочены по их члену ISBN. Аргумент конструктора можно записать как compareIsbn, вместо &compareIsbn, поскольку при использовании имени функции оно автоматически преобразуется в указатель, если это нужно (см. раздел 6.7). С тем же результатом можно написать &compareIsbn.
Упражнение 11.9. Определите карту, которая ассоциирует слова со списком номеров строк, в которых оно встречается.
Упражнение 11.10. Можно ли определить карту для типов vector::iteratorи int? А для типов list::iteratorи int? Если нет, то почему?
Упражнение 11.11. Переопределите bookstore, не используя спецификатор decltype.
11.2.3. Тип pair
Прежде чем перейти к рассмотрению действий с ассоциативными контейнерами, имеет смысл ознакомиться с библиотечным типом pair(пара), определенным в заголовке utility.
Объект типа pairхранит две переменные-члена. Подобно контейнерам, тип pair является шаблоном, позволяющим создавать конкретные типы. При создании пары следует предоставить имена двух типов, которые будут типами ее двух переменных-членов. Совпадать эти типы вовсе не обязаны.
pair anon; // содержит две строки
pair word_count; // содержит строку и целое число
pair> line; // содержит строку и vector
При создании объекта пары без указания инициализирующих значений используются стандартные конструкторы типов его переменных-членов. Таким образом, пара anonсодержит две пустые строки, а пара line— пустую строку и пустой вектор целых чисел. Значением переменной-члена типа intв паре word_countбудет 0, а его переменная-член типа stringокажется инициализирована пустой строкой.
Можно также предоставить инициализаторы для каждого члена пары:
pair author{"James", "Joyce"};
Этот код создает пару по имени author, инициализированную значениями "James"и "Joyce".
В отличие от других библиотечных типов, переменные-члены класса pair являются открытыми (см. раздел 7.2). Эти члены — first(первый) и second(второй) соответственно. К ним можно обращаться непосредственно, используя обычный точечный оператор (см. раздел 1.5.2), как, например, было сделано в операторе вывода программы подсчета слов в разделе 11.1:
// отобразить результаты
cout << w.first << " occurs " << w.second
<< ((w.second > 1) ? " times" : " time") << endl;
где w— ссылка на элемент карты. Элементами карты являются пары. В данном операторе выводится переменная-член firstэлемента, являющаяся ключом, затем переменная-член secondэлемента, являющаяся счетчиком. Библиотека определяет весьма ограниченный набор операций с парами, который приведен в табл. 11.2.
Таблица 11.2. Операции с парами
pair p; |
p— пара с переменными-членами типов T1и T2, инициализированными значением по умолчанию (см. раздел 3.3.1) |
pair р(v1, v2); |
p— пара с переменными-членами типов T1и T2, инициализированными значениями v1и v2соответственно |
pair р = {v1, v2}; |
Эквивалент p(v1, v2) |
make_pair(v1, v2) |
Возвращает пару, инициализированную значениями v1и v2. Тип пары выводится из типов значений v1и v2 |
p.first |
Возвращает открытую переменную-член firstпары p |
p.second |
Возвращает открытую переменную-член secondпары p |
p1 опсравн p2 |
Операторы сравнения ( <, >, <=, >=). Сравнение осуществляется подобно упорядочиванию в словаре, т.е. оператор <возвращает значение trueв случае, если p1.first < p2.firstили !(p2.first < p1.first) && p1.second < p2.second |
p1 == p2, p1 != p2 |
Две пары равны, если их первый и второй члены соответственно равны. При сравнении используется оператор ==хранимых элементов |
pair
Предположим, некая функция должна возвратить значение типа pair. По новому стандарту возможна списочная инициализация возвращаемого значения (см. раздел 6.3.2):
pair
process(vector &v) {
// обработка v
if (!v.empty())
return {v.back(), v.back().size()}; // списочная инициализация
else
return pair(); // возвращаемое значение создано явно
}
Если вектор vне пуст, возвращается пара, состоящая из последней строки в векторе vи размера этой строки. В противном случае явно создается и возвращается пустая пара.
В прежних версиях языка С++ нельзя было использовать инициализаторы в скобках для возвращения типа, подобного pair. Вместо этого можно было написать оба оператора returnкак явно созданное возвращаемое значение:
if (!v.empty())
return pair(v.back(), v.back().size());
В качестве альтернативы можно использовать функцию make_pair()для создания новой пары соответствующего типа из двух аргументов:
if (!v.empty())
return make_pair(v.back(), v.back().size());
Упражнение 11.12. Напишите программу, читающую последовательность строк и целых чисел, сохраняя каждую прочитанную пару в объекте класса pair. Сохраните пары в векторе.
Упражнение 11.13. Существует по крайней мере три способа создания пар в программе предыдущего упражнения. Напишите три версии программы, создающей пары каждым из этих способов. Укажите, какая из форм проще и почему.
Читать дальшеИнтервал:
Закладка: