Standard Template Library часть 1

Содержание

Слайд 2

Стандартная библиотека

Потоковые классы
Строковые классы
Контейнерные классы – классы для хранения данных, реализующие наиболее

Стандартная библиотека Потоковые классы Строковые классы Контейнерные классы – классы для хранения
распространенные структуры данных, например, очередь, стек, линейный список.
Алгоритмы – классы, реализующие процедуры для обработки данных контейнеров различными способами
Итераторы – обобщение указателей, они ссылаются на элементы контейнера. Итераторы связывают алгоритмы с контейнерами.
Математические классы – поддерживают эффективную обработку массивов с плавающей точкой, работу с комплексными числами
Диагностические классы – обеспечивают динамическую идентификацию типов и объектно-ориентированную обработку ошибок
Остальные классы – обеспечивают динамическое перераспределение памяти, адаптацию к локальным особенностям, обработку функциональных объектов

STL

Слайд 3

Достоинства и недостатки STL

Достоинства
Повышение надежности программ, а также их переносимости и универсальности
Уменьшение

Достоинства и недостатки STL Достоинства Повышение надежности программ, а также их переносимости
объема исходного кода
Уменьшение времени работы программиста
Недостатки
Снижение быстродействия программы
Необходимость изучения STL

Слайд 4

Потоковые классы

Потоковые классы

Слайд 5

Потоковые классы

Флаг форматирования – отдельные биты в поле x_flags типа long класса

Потоковые классы Флаг форматирования – отдельные биты в поле x_flags типа long
ios. Они работают переключателями, определяющими различные форматы и способы ввода/вывода. Задание флагов осуществляется методом setf(flags), а получение flags();
Манипуляторы – это инструкции форматирования, которые вставляются прямо в поток.

Слайд 6

Флаги форматирования

Флаги форматирования

Слайд 7

Пример использования флагов форматирования

//Сохраняем текущие значения флагов
long prev_flags = cout.flags();
//Выводим вещественное число,

Пример использования флагов форматирования //Сохраняем текущие значения флагов long prev_flags = cout.flags();
на экране - экспоненциальная форма
cout << 1e-10 << endl;
//Задаем фиксированный формат вывода с обязательной точкой
cout.setf(ios::fixed | ios::showpoint);
//Задаем вывод 10 знаков после десятичной точки
cout.precision(10);
//Выводим то же число и видим все десять знаков
cout << 1e-10 << endl;
//Восстанавливаем флаги
cout.setf(prev_flags);

Слайд 8

Манипуляторы

Манипуляторы

Слайд 9

Пример использования манипуляторов

#include
………
cout << hex << 31 << " " <<

Пример использования манипуляторов #include ……… cout cout
oct << 31 << " " << dec << 31 << endl;
cout << setw(10) << 666 << endl;

Слайд 10

Контейнеры

Последовательные контейнеры – обеспечивают хранение конечного количества однотипных величин в виде непрерывной

Контейнеры Последовательные контейнеры – обеспечивают хранение конечного количества однотипных величин в виде
памяти
Векторы – vector
Двусторонние очереди – deque
Линейные двусвязные списки – list
Их адаптеры:
Стеки – stack
Очереди – queue
Очереди с приоритетами – priority_queue
Ассоциативные контейнеры – обеспечивают быстрый доступ к данным по ключу. Построены на базе сбалансированных деревьев
Словари – map
Словари с дубликатами – multimap
Множества – set
Мультимножества (множества с дубликатами) – multiset
Битовые множества - bitset

Слайд 11

Характеристика контейнеров

Позволяют хранить данные произвольных типов
Обеспечивают стандартизированный интерфейс для выполнения операций над

Характеристика контейнеров Позволяют хранить данные произвольных типов Обеспечивают стандартизированный интерфейс для выполнения
хранимыми данными
Стандартизирован только интерфейс, возможны разные реализации контейнерных классов разными разработчиками STL/сред программирования

Слайд 12

Типы, определения которых содержатся в каждом контейнерном классе STL

Типы, определения которых содержатся в каждом контейнерном классе STL

Слайд 13

Понятие итератора

Итератор является аналогом указателя на элемент. Используется для просмотра контейнера в

Понятие итератора Итератор является аналогом указателя на элемент. Используется для просмотра контейнера
прямом или обратном порядке.
Итератор умеет:
ссылаться на элемент контейнера (операция *);
переходить к следующему элементу контейнера (операция ++).
Константные итераторы необходимы для работы с элементами контейнера без возможности их изменения.

Слайд 14

Итераторы просмотра элементов контейнеров

Итераторы просмотра элементов контейнеров

Слайд 15

Методы, позволяющие определить сведения о размере контейнера

Методы, позволяющие определить сведения о размере контейнера

Слайд 16

Заголовочные файлы для работы с библиотекой STL

algorithm
deque
funсtional
iterator
list
map
memory
numeric
queue
set
stack
utility
vector

Заголовочные файлы для работы с библиотекой STL algorithm deque funсtional iterator list

Слайд 17

Характеристика общих операций для последовательных контейнеров

“-” – операция в контейнере не реализована
“+”

Характеристика общих операций для последовательных контейнеров “-” – операция в контейнере не
– операция выполняется за постоянное время, не зависящее от размера
контейнера n
“(+)” – операция выполняется за время, пропорциональное n

Слайд 18

Векторы - vector

Являются аналогами динамических массивов с возможностью изменения размера
Эффективно реализуют операции

Векторы - vector Являются аналогами динамических массивов с возможностью изменения размера Эффективно
произвольного доступа к элементам, добавления в конец и удаления с конца
Неэффективно реализуют операции вставки и удаления в начало или середину

Слайд 19

Пример использования вектора

int n, x;
vector v; //объявляем вектор целых чисел
cout <<

Пример использования вектора int n, x; vector v; //объявляем вектор целых чисел
"n = ";
cin >> n; //вводим количество элементов
for (int i = 0; i < n; i++) { //вводим элементы
cin >> x;v.push_back(x); //добавляем очередной элемент в конец вектора
}
//Вычисление среднего арифметического
double avg = 0.0;
for (int i = 0; i < v.size(); i++)
avg += v[i]; //обращение к элементам вектора по индексу
avg /= v.size();
cout << "Average value = " << avg << endl;
//Печать вектора на экран с использованием итератора I
for (vector::iterator i = v.begin(); i != v.end(); i++)
{
cout << *i << " ";
}
cout << endl;

Слайд 20

Конструкторы создания вектора

Конструктор по умолчанию
explicit vector();
Конструктор, создающий вектор размера n и заполняющий

Конструкторы создания вектора Конструктор по умолчанию explicit vector(); Конструктор, создающий вектор размера
его значением value. Если value не указано, то для встроенных типов происходит инициализация нулем, для пользовательских – вызывается конструктор по умолчанию
explicit vector(size_type n, const T& value = T());
Конструктор копирования значений из диапазона итераторов [first, last) другого контейнерного класса
vector(InputIter first, InputIter last);
Конструктор копирования
vector(const vector& x);

explicit запрещает неявное преобразование типов при объявлении векторов с инициализацией

Слайд 21

Пример использования конструкторов (1)

vector v1; //используется первый конструктор
vector v2(10, 0.5); //второй конструктор
v2[0]

Пример использования конструкторов (1) vector v1; //используется первый конструктор vector v2(10, 0.5);
= 666.666;
vector v3(v2.begin(), v2.begin() + 5);//третий конст-р
vector v4 = v2; //четвертый конструктор
cout << "v1 :" << endl;
for (vector::iterator i = v1.begin(); i != v1.end(); i++)
cout << *i << " ";
cout << endl; cout << "v2 :" << endl;
for (vector::iterator i = v2.begin(); i != v2.end(); i++)
cout << *i << " ";
cout << endl; cout << "v3 :" << endl;
for (vector::iterator i = v3.begin(); i != v3.end(); i++)
cout << *i << " ";
cout << endl; cout << "v4 :" << endl;
for (vector::iterator i = v4.begin(); i != v4.end(); i++)
cout << *i << " ";
cout << endl;

Слайд 22

Пример использования конструкторов (2)

vector v1;
vector v2(10, 0.5);
v2[0] = 666.666;
vector v3(v2.begin(), v2.begin() +

Пример использования конструкторов (2) vector v1; vector v2(10, 0.5); v2[0] = 666.666;
5);
vector v4 = v2;
cout << "v1 :" << endl << v1;
cout << "v2 :" << endl << v2;
cout << "v3 :" << endl << v3;
cout << "v4 :" << endl << v4;
//Шаблонная функция печати элементов вектора
template
ostream& operator<< (ostream& out, const vector& v)
{
for (vector::const_iterator i = v.begin(); i != v.end(); i++)
out << *i << " ";
cout << endl;
return out;
}

Далее в примерах будет использоваться
данная шаблонная функция печати вектора

Слайд 23

Присваивание векторов

С помощью операции присваивания
vector& operator= (const vector& x);
С помощью методов
void assign(size_type

Присваивание векторов С помощью операции присваивания vector & operator= (const vector &
n, const T& value);
void assign(InputIter first, InputIer last);
Использование методов аналогично соответствующим конструкторам.

Слайд 24

Пример использования присваивания

vector v1, v2, v3, v4;
for (int i = 0; i

Пример использования присваивания vector v1, v2, v3, v4; for (int i =
< 10; i++)
v1.push_back(i * i);
v2 = v1; //Вызов операции =
//Присвоение v3 десяти значений 777
v3.assign(10, 777);
//Присвоение v4 значений из диапазона итераторов [v1.begin() + 2, v1.begin() + 5),
//т.е. значений с индексами 2, 3, 4
v4.assign(v1.begin() + 2, v1.begin() + 5);
cout << "v1 :" << endl << v1;
cout << "v2 :" << endl << v2;
cout << "v3 :" << endl << v3;
cout << "v4 :" << endl << v4;

Слайд 25

Доступ к элементам вектора

С помощью операции индексирования []:
reference operator[] (size_type i);
По индексу

Доступ к элементам вектора С помощью операции индексирования []: reference operator[] (size_type
с помощью метода:
reference at(size_type i);
При выходе за границу вектора генерируется исключение out_of_range
Обращение к первому элементу вектора
reference front();
Обращение к последнему элементу вектора
reference back();

Слайд 26

Знаки операций, определенные для векторов

Знаки операций, определенные для векторов

Слайд 27

Получение размера памяти и ее резервирование

Получение размера занимаемой памяти
size_type capacity() const;
Ручное резервирование

Получение размера памяти и ее резервирование Получение размера занимаемой памяти size_type capacity()
памяти под n элементов вектора. Память выделяется, но сами элементы не добавляются
void reserve(size_type n);
Память под вектор выделяется динамически блоками по 256 или 1024 элемента. Перераспределение памяти происходит динамически при превышении текущего объема. После перераспределения любые итераторы, указывающие на вектор становятся недействительными. Функция reserve позволяет предварительно зарезервировать память под то, количество элементов, которые могут оказаться в векторе в ходе выполнения программы.

Слайд 28

Замечание

Если заранее известен размер вектора, то чтобы сократить накладные расходы по работе

Замечание Если заранее известен размер вектора, то чтобы сократить накладные расходы по
с памятью, постарайтесь зарезервировать память

Слайд 29

Пример использования резервирования

int n, x;
vector v; //объявляем вектор целых чисел
cout <<

Пример использования резервирования int n, x; vector v; //объявляем вектор целых чисел
"n = ";
cin >> n; //вводим количество элементов
v.reserve(n);
for (int i = 0; i < n; i++) { //вводим элементы
cin >> x;v.push_back(x); //добавляем очередной элемент в конец вектора
}
//Вычисление среднего арифметического
double avg = 0.0;
for (int i = 0; i < v.size(); i++)
avg += v[i]; //обращение к элементам вектора по индексу
avg /= v.size();
cout << "Average value = " << avg << endl;
//Печать вектора на экран с использованием итератора I
for (vector::iterator i = v.begin(); i != v.end(); i++)
{
cout << *i << " ";
}
cout << endl;

Слайд 30

Добавление в конец вектора, удаление из конца

Добавление в конец вектора
void push_back(const& T

Добавление в конец вектора, удаление из конца Добавление в конец вектора void
value);
Удаление из конца вектора
void pop_back();

Слайд 31

Методы вставки значений в вектор

Вставка значения value в позицию, на которую указывает

Методы вставки значений в вектор Вставка значения value в позицию, на которую
итератор pos, возвращаемое значение – итератор, указываюший на место вставки
iterator insert(iterator pos,
const T& value);
Вставка в позицию pos вектора n одинаковых элементов со значением value
void insert(iterator pos, size_type n,
const T& value);
Вставка в позицию pos вектора из элементов другого контейнера из диапазона итераторов [first last)
void insert(iterator pos,
InputIter first,
InputIter last);

Слайд 32

Пример вставки значений в вектор

vector v, v1;
for (int i = 0; i

Пример вставки значений в вектор vector v, v1; for (int i =
< 10; i++)
v.push_back(i);
cout << v;
//Вставку в позицию итератора v.begin() + 1
//(перед элементом с индексом 1) значения 777
v.insert(v.begin() + 1, 777);
cout << v;
//Вставка в конец вектора 5 значений 69
v.insert(v.end(), 5, 69);
cout << v;
for (int i = 0; i < 5; i++)
v1.push_back(i * i);
//Вставка в начало вектора v всех значений вектора v1
v.insert(v.begin(), v1.begin(), v1.end());
cout << v;

Слайд 33

Методы удаления элементов из вектора

Удаление одного элемента. pos – итератор, указывающий на

Методы удаления элементов из вектора Удаление одного элемента. pos – итератор, указывающий
него. Возвращаемое значение – итератор, указывающий на элемент после удаленного
iterator erase(iterator pos);
Удаление нескольких элементов из диапазона итераторов [first, last)
iterator erase(iterator first,
iterator last);

Слайд 34

Пример удаления значений из вектора

vector v;
for (int i = 0; i <

Пример удаления значений из вектора vector v; for (int i = 0;
10; i++)
v.push_back(i);
cout << v;
//Удаление элемента, на который указывает итератор
//v.begin() + 3, т.е. элемента с индексом 3
v.erase(v.begin() + 3);
cout << v;
//Удаление предпоследнего элемента
v.erase(v.end() - 2);
cout << v;
//Удаление первых трех элементов
v.erase(v.begin(), v.begin() + 3);
cout << v;

Слайд 35

Прочие методы работы с векторами

Обмен местами векторов
void swap(vector& x);
Очистка вектора
void clear();
Изменение размера

Прочие методы работы с векторами Обмен местами векторов void swap(vector & x);
вектора, n – новый размер. Если n меньше текущего размера вектора, то удаляются последние элементы, если больше – добавляются новые элементы равные value в конец вектора
void resize(size_type n, T value = T());
Имя файла: Standard-Template-Library-часть-1.pptx
Количество просмотров: 199
Количество скачиваний: 0