Стенли Липпман - Язык программирования C++. Пятое издание
- Название:Язык программирования C++. Пятое издание
- Автор:
- Жанр:
- Издательство:Издательский дом Вильямс
- Год:2014
- Город:Москва
- ISBN:978-5-8459-1839-0
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Стенли Липпман - Язык программирования C++. Пятое издание краткое содержание
Вы держите в руках новое издание популярного и исчерпывающего бестселлера по языку программирования С++, которое было полностью пересмотрено и обновлено под
. Оно поможет вам быстро изучить язык и использовать его весьма эффективными и передовыми способами. В соответствии с самыми передовыми и современными методиками изложения материала авторы демонстрируют использование базового языка и его стандартной библиотеки для разработки эффективного, читабельного и мощного кода.
С самого начала этой книги читатель знакомится со стандартной библиотекой С++, ее самыми популярными функциями и средствами, что позволяет сразу же приступить к написанию полезных программ, еще не овладев всеми нюансами языка. Большинство примеров из книги было пересмотрено так, чтобы использовать новые средства языка и продемонстрировать их наилучшие способы применения. Эта книга — не только проверенное руководство для новичков в С++, она содержит также авторитетное обсуждение базовых концепций и методик языка С++ и является ценным ресурсом для опытных программистов, особенно желающих побыстрей узнать об усовершенствованиях С++11.
Стенли Б. Липпман Жози Лажойе Барбара Э. Му • Узнайте, как использовать новые средства языка С++11 и стандартной библиотеки для быстрого создания надежных программ, а также ознакомьтесь с высокоуровневым программированием
• Учитесь на примерах, в которых показаны передовые стили программирования и методики проектирования
• Изучите принципы и узнайте почему язык С++11 работает именно так
• Воспользуйтесь множеством перекрестных ссылок, способных помочь вам объединить взаимосвязанные концепции и проникнуть в суть
• Ознакомьтесь с современными методиками обучения и извлеките пользу из упражнений, в которых подчеркиваются ключевые моменты, позволяющие избежать проблем
• Освойте лучшие методики программирования и закрепите на практике изученный материал
Исходный код примеров можно загрузить с веб-страницы книги на сайте издательства по адресу: http://www.williamspublishing.com
Язык программирования C++. Пятое издание - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
В двумерном массиве первую размерность зачастую называют рядом (row), а вторую — столбцом (column).
Подобно любым массивам, элементы многомерного массива можно инициализировать, предоставив в фигурных скобках список инициализаторов. Многомерные массивы могут быть инициализированы списками значений в фигурных скобках для каждого ряда.
int ia[3][4] = { // три элемента; каждый - массив размером 4
{0, 1, 2, 3}, // инициализаторы ряда 0
{4, 5, 6, 7}, // инициализаторы ряда 1
{8, 9, 10, 11} // инициализаторы ряда 2
};
Вложенные фигурные скобки необязательны. Следующая инициализация эквивалентна, хотя и значительно менее очевидна:
// эквивалентная инициализация без необязательных вложенных фигурных
// скобок для каждого ряда
int ia[3][4] = {0,1,2,3,4,5,6,7,8,9,10,11};
Как и в случае одномерных массивов, элементы списка инициализации могут быть пропущены. Следующим образом можно инициализировать только первый элемент каждого ряда:
// явная инициализация только нулевого элемента в каждом ряду
int ia[3][4] = {{ 0 }, { 4 }, { 8 } };
Остальные элементы инициализируются значением по умолчанию, как и обычные одномерные массивы (см. раздел 3.5.1). Но если опустить вложенные фигурные скобки, то результаты были бы совсем иными:
// явная инициализация нулевого ряда;
// остальные элементы инициализируются
// по умолчанию
int ix[3][4] = {0, 3, 6, 9};
Этот код инициализирует элементы первого ряда. Остальные элементы инициализируются значением 0.
Подобно любому другому массиву, для доступа к элементам многомерного массива можно использовать индексирование. При этом для каждой размерности используется отдельный индекс.
Если выражение предоставляет столько же индексов, сколько у массива размерностей, получается элемент с определенным типом. Если предоставить меньше индексов, чем есть размерностей, то результатом будет элемент внутреннего массива по указанному индексу:
// присваивает первый элемент массива arr последнему элементу
// в последнем ряду массива ia
ia[2][3] = arr[0][0][0];
int (&row)[4] = ia[1]; // связывает ряд второго массива с четырьмя
// элементами массива ia
В первом примере предоставляются индексы для всех размерностей обоих массивов. Левая часть, ia[2]
, возвращает последний ряд массива ia
. Она возвращает не отдельный элемент массива, а сам массив. Индексируем массив, выбирая элемент [3]
, являющийся последним элементом данного массива.
Точно так же, правый операнд имеет три размерности. Сначала выбирается массив по индексу 0
из наиболее удаленного массива. Результат этой операции — массив (многомерный) размером 20. Используя массив размером 30, извлекаем из этого массива с 20 элементами первый элемент. Затем выбирается первый элемент из полученного массива.
Во втором примере row
определяется как ссылка на массив из четырех целых чисел. Эта ссылка связывается со вторым рядом массива ia
.
constexpr size_t rowCnt = 3, colCnt = 4;
int ia[rowCnt][colCnt]; // 12 неинициализированных элементов
// для каждого ряда
for (size_t i = 0; i != rowCnt; ++i) {
// для каждого столбца в ряду
for (size_t j = 0; j != colCnt; ++j) {
// присвоить элементу его индекс как значение
ia[i][j] = i * colCnt + j;
}
}
Внешний цикл for
перебирает каждый элемент массива ia
. Внутренний цикл for
перебирает элементы внутренних массивов. В данном случае каждому элементу присваивается значение его индекса в общем массиве.

for
с многомерными массивамиПо новому стандарту предыдущий цикл можно упростить с помощью серийного оператора for
:
size_t cnt = 0;
for (auto &row : ia) // для каждого элемента во внешнем массиве
for (auto &col : row) { // для каждого элемента во внутреннем массиве
col = cnt; // присвоить значение текущему элементу
++cnt; // инкремент cnt
}
Этот цикл присваивает элементам массива ia
те же значения, что и предыдущий цикл, но на сей раз управление индексами берет на себя система. Значения элементов необходимо изменить, поэтому объявляем управляющие переменные row
и col
как ссылки (см. раздел 3.2.3). Первый оператор for
перебирает элементы массива ia
, являющиеся массивами из 4 элементов. Таким образом, типом row
будет ссылка на массив из четырех целых чисел. Второй цикл for
перебирает каждый из этих массивов по 4 элемента. Следовательно, col
имеет тип int&
. На каждой итерации значение cnt
присваивается следующему элементу массива ia
, а затем осуществляется инкремент переменной cnt
.
В предыдущем примере как управляющие переменные цикла использовались ссылки, поскольку элементы массива необходимо было изменять. Однако есть и более серьезная причина для использования ссылок. Рассмотрим в качестве примера следующий цикл:
for (const auto &row : ia) // для каждого элемента во внешнем массиве
for (auto col : row) // для каждого элемента во внутреннем массиве
cout << col << endl;
Этому циклу запись в элементы не нужна, но все же управляющая переменная внешнего цикла определена как ссылка. Это сделано для того, чтобы избежать преобразования обычного массива в указатель (см. раздел 3.5.3). Если пренебречь ссылкой и написать эти циклы так, то компиляция потерпит неудачу:
for (auto row : ia)
for (auto col : row)
Как и прежде, первый цикл for
перебирает элементы массива ia
, являющиеся массивами по 4 элемента. Поскольку row
не ссылка, при его инициализации компилятор преобразует каждый элемент массива (как и любой другой объект типа массива) в указатель на первый элемент этого массива. В результате типом row
в этом цикле будет int*
. Внутренний цикл for
некорректен. Несмотря на намерения разработчика, этот цикл пытается перебрать указатель типа int*
.
Чтобы использовать многомерный массив в серийном операторе
for
, управляющие переменные всех циклов, кроме самого внутреннего, должны быть ссылками.
Подобно любым другим массивам, имя многомерного массива автоматически преобразуется в указатель на первый его элемент.
Читать дальшеИнтервал:
Закладка: