Стенли Липпман - Язык программирования C++. Пятое издание
- Название:Язык программирования C++. Пятое издание
- Автор:
- Жанр:
- Издательство:Издательский дом Вильямс
- Год:2014
- Город:Москва
- ISBN:978-5-8459-1839-0
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Стенли Липпман - Язык программирования C++. Пятое издание краткое содержание
Вы держите в руках новое издание популярного и исчерпывающего бестселлера по языку программирования С++, которое было полностью пересмотрено и обновлено под
. Оно поможет вам быстро изучить язык и использовать его весьма эффективными и передовыми способами. В соответствии с самыми передовыми и современными методиками изложения материала авторы демонстрируют использование базового языка и его стандартной библиотеки для разработки эффективного, читабельного и мощного кода.
С самого начала этой книги читатель знакомится со стандартной библиотекой С++, ее самыми популярными функциями и средствами, что позволяет сразу же приступить к написанию полезных программ, еще не овладев всеми нюансами языка. Большинство примеров из книги было пересмотрено так, чтобы использовать новые средства языка и продемонстрировать их наилучшие способы применения. Эта книга — не только проверенное руководство для новичков в С++, она содержит также авторитетное обсуждение базовых концепций и методик языка С++ и является ценным ресурсом для опытных программистов, особенно желающих побыстрей узнать об усовершенствованиях С++11.
Стенли Б. Липпман Жози Лажойе Барбара Э. Му • Узнайте, как использовать новые средства языка С++11 и стандартной библиотеки для быстрого создания надежных программ, а также ознакомьтесь с высокоуровневым программированием
• Учитесь на примерах, в которых показаны передовые стили программирования и методики проектирования
• Изучите принципы и узнайте почему язык С++11 работает именно так
• Воспользуйтесь множеством перекрестных ссылок, способных помочь вам объединить взаимосвязанные концепции и проникнуть в суть
• Ознакомьтесь с современными методиками обучения и извлеките пользу из упражнений, в которых подчеркиваются ключевые моменты, позволяющие избежать проблем
• Освойте лучшие методики программирования и закрепите на практике изученный материал
Исходный код примеров можно загрузить с веб-страницы книги на сайте издательства по адресу: http://www.williamspublishing.com
Язык программирования C++. Пятое издание - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
В программах ранее уже использовались преобразования типов класса, когда символьная строка в стиле С использовалась там, где ожидался библиотечный тип string
(см. раздел 3.5.5), а также при чтении из потока istream
в условии.
string s, t = "a value"; // с имвольный строковый литерал преобразован
// в тип string
while (cin >> s) // условие while преобразует cin в bool
Условие ( cin >> s
) читает поток cin
и возвращает его же как результат. Условия ожидают значение типа bool
, но оно проверяет значение типа istream
. Библиотека IO определяет преобразование из типа istream
в bool
. Это преобразование используется автоматически, чтобы преобразовать поток cin
в тип bool
. Результирующее значение типа bool
зависит от состояния потока. Если последнее чтение успешно, то преобразование возвращает значение true
. Если последняя попытка потерпела неудачу, то преобразование возвращает значение false
.
4.11.3. Явные преобразования
Иногда необходимо явно преобразовать объект в другой тип. Например, в следующем коде может понадобиться использование деления с плавающей точкой:
int i, j;
double slope = i/j;
Для этого необходим способ явного преобразования переменных i
и/или j
в тип double
. Для явного преобразования используется приведение (cast) типов.
Хотя приведение время от времени необходимо, оно довольно опасно.
Именованный оператор приведения имеет следующую форму:
имя_приведения < тип >( выражение );
где тип
— это результирующий тип преобразования, а выражение
— приводимое значение. Если тип
— ссылка, то результат l-значение. Имя_приведения
может быть одним из следующих: static_cast
, dynamic_cast
, const_cast
и reinterpret_cast
. Приведение dynamic_cast
, обеспечивающее идентификацию типов времени выполнения, рассматривается в разделе 19.2. Имя_приведения
определяет, какое преобразование осуществляется.
static_cast
Любое стандартное преобразование типов, кроме задействующего спецификатор const
нижнего уровня, можно затребовать, используя оператор static_cast
. Например, приведя тип одного из операндов к типу double
, можно заставить выражение использовать деление с плавающей точкой:
// приведение для вынужденного деления с плавающей точкой
double slope = static_cast(j) / i;
Оператор static_cast
зачастую полезен при присвоении значения большего арифметического типа переменной меньшего. Приведение сообщает и читателю программы, и компилятору, что мы знаем и не беспокоимся о возможной потере точности. При присвоении большего арифметического типа меньшему компиляторы зачастую выдают предупреждение. При явном приведении предупреждающее сообщение не выдается.
Оператор static_cast
полезен также при выполнении преобразований, которые компилятор не выполняет автоматически. Например, его можно использовать для получения значения указателя, сохраняемого в указателе void*
(см. раздел 2.3.2):
void* p = &d; // ok: адрес любого неконстантного объекта может
// храниться в указателе void*
// ok: преобразование void* назад в исходный тип указателя
double *dp = static_cast(p);
После сохранения адреса в указателе типа void*
можно впоследствии использовать оператор static_cast
и привести указатель к его исходному типу, что позволит сохранить значение указателя. Таким образом, результат приведения будет равен первоначальному значению адреса. Однако следует быть абсолютно уверенным в том, что тип, к которому приводится указатель, является фактическим типом этого указателя; при несоответствии типов результат непредсказуем.
const_cast
Оператор const_cast
изменяет только спецификатор const
нижнего уровня своего операнда (см. раздел 2.4.3):
const char *pc;
char *p = const_cast(pc); // ok: однако запись при помощи p
// указателя непредсказуема
Принято говорить, что приведение, преобразующее константный объект в неконстантный, "сбрасывает const
". При сбросе константности объекта компилятор больше не будет препятствовать записи в этот объект. Если объект первоначально не был константным, использование приведения для доступа на запись вполне допустимо. Но применение оператора const_cast
для записи в первоначально константный объект непредсказуемо.
Только оператор const_cast
позволяет изменить константность выражения. Попытка изменить константность выражения при помощи любого другого именованного оператора приведения закончится ошибкой компиляции. Аналогично нельзя использовать оператор const_cast
для изменения типа выражения:
const char *cp;
// ошибка: static_cast не может сбросить const
char *q = static_cast(cp);
static_cast(cp); // ok: преобразует строковый литерал в строку
const_cast(cp); // ошибка: const_cast изменяет только
// константность
Оператор const_cast
особенно полезен в контексте перегруженных функций, рассматриваемых в разделе 6.4.
reinterpret_cast
Оператор reinterpret_cast
осуществляет низкоуровневую интерпретацию битовой схемы своих операндов. Рассмотрим, например, следующее приведение:
int *ip;
char *pc = reinterpret_cast(ip);
Никогда не следует забывать, что фактическим объектом, на который указывает указатель pc
, является целое число, а не символ. Любое использование указателя pc
, подразумевающее, что это обычный символьный указатель, вероятно, потерпит неудачу во время выполнения. Например, следующий код, вероятней всего, приведет к непредвиденному поведению во время выполнения:
string str(pc);
Использование указателя pc
для инициализации объекта типа string
— хороший пример небезопасности оператора reinterpret_cast
. Проблема в том, что при изменении типа компилятор не выдаст никаких предупреждений или сообщений об ошибке. При инициализации указателя pc
адресом типа int
компилятор не выдаст ни предупреждения, ни сообщения об ошибке, поскольку явно указано, что это и нужно. Однако любое последующее применение указателя pc
подразумевает, что он содержит адрес значения типа char*
. Компилятор не способен выяснить, что фактически это указатель на тип int
. Таким образом, инициализация строки str
при помощи указателя pc
вполне правомерна, хотя в данном случае абсолютно бессмысленна, если не хуже! Отследить причину такой проблемы иногда чрезвычайно трудно, особенно если приведение указателя ip
к pc
происходит в одном файле, а использование указателя pc
для инициализации объекта класса string
— в другом.
Интервал:
Закладка: