Д. Стефенс - C++. Сборник рецептов

Здесь есть возможность читать онлайн «Д. Стефенс - C++. Сборник рецептов» весь текст электронной книги совершенно бесплатно (целиком полную версию без сокращений). В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Город: Москва, Год выпуска: 2007, ISBN: 2007, Издательство: КУДИЦ-ПРЕСС, Жанр: Программирование, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

C++. Сборник рецептов: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «C++. Сборник рецептов»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

Данная книга написана экспертами по C++ и содержит готовые рецепты решения каждодневных задач для программистов на С++. Один из авторов является создателем библиотеки Boost Iostreams и нескольких других библиотек C++ с открытым исходным кодом. В книге затрагивается множество тем, вот лишь некоторые из них: работа с датой и временем; потоковый ввод/вывод; обработка исключений; работа с классами и объектами; сборка приложений; синтаксический анализ XML-документов; программирование математических задач. Читатель сможет использовать готовые решения, а сэкономленное время и усилия направить на решение конкретных задач.

C++. Сборник рецептов — читать онлайн бесплатно полную книгу (весь текст) целиком

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «C++. Сборник рецептов», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

const_row_type operator[](int n) const { return row_begin(n); }

self& operator+=(const self& x) { m += x.m; return *this; }

self& operator-=(const self& x) { m -= x.m; return *this; }

self& operator+=(value_type x) { m += x; return *this; }

self& operator-=(value_type x) { m -= x; return *this; }

self& operator*=(value_type x) { m *= x; return *this; }

self& operator/=(value_type x) { m /= x; return *this; }

self& operator%=(value_type x) { m %= x; return *this; }

self operator-() { return -m; }

self operator+() { return +m; }

self operator!() { return !m; }

self operator~() { return ~m; }

// дружественные операторы

friend self operator+(const self& x, const self& y) { return self(x) += y; }

friend self operator-(const self& x, const self& y) { return self(x) -= y; }

friend self operator+(const self& x, value_type y) { return self(x) += y; }

friend self operator-(const self& x, value_type y) { return self(x) -= y; }

friend self operator*(const self& x, value type y) { return self(x) *= y; }

friend self operator/(const self& x, value_type y) { return self(x) /= y; }

friend self operator%(const self& x, value_type y) { return self(x) %= y; }

private:

mutable valarray m;

int nrows;

int ncols;

};

#endif

Пример 11.29 показывает, как можно использовать шаблонный класс matrix.

Пример 11.29. Применение шаблона matrix

#include "matrix.hpp"

#include

using namespace std;

int main() {

matrix m(2,2);

m = 0;

m[0][0] = 1;

m[1][1] = 1;

m *= 2;

cout << "(" << m[0][0] << "," << m[0][1] << ")" << endl;

cout << "(" << m[1][0] << "," << m[1][1] << ")" << endl;

}

Программа примера 11.29 выдает следующий результат.

(2,0)

(0,2)

Обсуждение

Проект шаблона матрицы, представленный в примере 11.28, в значительной степени инспирирован шаблоном матрицы Бьерна Страуструпа (Bjarne Stroustrup) из его книги « The C++ Programming Language », 3-е издание (издательство «Addison Wesley»). Реализация Страуструпа отличается тем, что его итератор использует класс sliceи указатель на valarrayдля индексации. Реализованная в примере 11.27 матрица использует вместо них итератор с шагом из рецепта 11.12, что делает итераторы более компактными и при некоторых реализациях более эффективными.

Шаблонный класс matrixпозволяет индексировать элемент i -й строки и j -го столбца, используя операцию двойной индексации. Например:

matrix m(100,100);

cout << "the element at row 24 and column 42 is " << m[24][42] << endl;

Шаблонный класс matrixтакже имеет функции-члены beginи end, т.е. его легко можно использовать в различных алгоритмах STL.

Пример 11.28 содержит строку, которая, возможно, вызывает у вас некоторое удивление. Имеется в виду следующее объявление.

mutable valarray m;

Объявление поля-члена mсо спецификатором mutableвынужденно. В противном случае я не мог бы обеспечить итераторы со спецификатором const, потому что нельзя создать итератор для const valarray.

Смотри также

Рецепты 11.15 и 11.16.

11.15. Реализация статической матрицы

Проблема

Требуется эффективно реализовать матрицу, когда ее размерность (т.е. количество строк и столбцов) постоянна и известна на этапе компиляции.

Решение

Когда размерность матрицы известна на этапе компиляции, компилятор может легко оптимизировать реализацию, в которой количество строк и столбцов задается в виде параметров шаблона, как показано в примере 11.30.

Пример 11.30. kmatrix.hpp

#ifndef KMATRIX_HPP

#define KMATRIX_HPP

#include "kvector.hpp"

#include "kstride_iter.hpp"

template

class kmatrix {

public:

// открытые имена, вводимые typedef

typedef Value_T value_type;

typedef kmatrix self;

typedef Value_T* iterator;

typedef const Value_T* const_iterator;

typedef kstride_iter row_type;

typedef kstride_iter col_type;

typedef kstride_iter const_row_type;

typedef kstride_iter const_col_type;

// открытые константы

static const int nRows = Rows_N;

static const int nCols = Cols_N;

// конструкторы

kmatrix() { m = Value_T(); }

kmatrix(const self& x) { m = x.m; }

explicit kmatrix(Value_T& x) { m = x.m; }

// открытые функции

static int rows() { return Rows_N; }

static int cols() { return Cols_N; }

row_type row(int n) { return row_type(begin() * (n * Cols_N)); }

col_type col(int n) { return col_type(begin() + n); }

const_row_type row(int n) const {

return const_row_type(begin() + (n * Cols_N));

}

const_col_type col(int n) const {

return const_col_type(begin() + n);

}

iterator begin() { return m.begin(); }

iterator end() { return m.begin() + size(); }

const_iterator begin() const { return m; }

const_iterator end() const { return m + size(); }

static int size() { return Rows_N * Cols_N; }

// операторы

row_type operator[](int n) { return row(n); }

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «C++. Сборник рецептов»

Представляем Вашему вниманию похожие книги на «C++. Сборник рецептов» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «C++. Сборник рецептов»

Обсуждение, отзывы о книге «C++. Сборник рецептов» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.