Читаем Руководство по стандартной библиотеке шаблонов (STL) полностью

Предполагается, что в дополнение к allocator поставщики библиотеки обеспечивают распределители для всех моделей памяти.

<p>Контейнеры</p>

Контейнеры - это объекты, которые содержат другие объекты. Они управляют размещением в памяти и свобождением этих объектов через конструкторы, деструкторы, операции вставки и удаления.

В следующей таблице мы полагаем, что X - контейнерный класс, содержащий объекты типа T, a и b - значения X, u - идентификатор, r - значение X&.

Таблица 8. Требования контейнеров

выражение возвращаемый тип семантика исполнения утверждение/примечание состояние до/после сложность
X::value_type Т-время компиляции
X::reference--- время компиляции
X::const_reference---время компиляции
X::pointer тип указателя, указывающий на X::reference-указатель на T в модели памяти, используемой контейнером время компиляции
X::iterator тип итератора, указывающий на X::reference-итератор любой категории, кроме итератора вывода. время компиляции
X::const_iterator тип итератора, указывающий на X::const_reference -постоянный итератор любой категории, кроме итератора вывода. время компиляции
X::difference_typeзнаковый целочисленный тип-идентичен типу расстояния X::iterator и X::const_iterator время компиляции
X::size_type беззнаковый целочисленный типsize_type может представлять любое неотрицательное значение difference_type время компиляции
X u;-после: u.size()==0. постоянная
X()-- X().size()==0. постоянная
X(a)-- a==X(a). линейная
X u(a); X u==a;-X u; u = a; после: u==a. линейная
(&a)-›~X() результат не используетсяпосле: a.size()==0. примечание: деструктор применяется к каждому элементу a, и вся память возвращается. линейная
a.begin() iterator; const_iterator для постоянного a--постоянная
a.end() iterator; const_iterator для постоянного a--постоянная
a==b обратимый в bool a.size()==b.size() && equal(a.begin(), a.end(), b.begin())== - это отношение эквивалентности. примечание: equal определяется в разделе алгоритмов. линейная
a!= b обратимый в bool!(a==b)-линейная
r = a X& if(&r!=&a){ (&r)-›X::~X(); new(&r)X(a); return r;}после: r==a.линейнaя
a.size() size_type size_type n = 0; distance(a.begin(), a.end(), n); return n;-постоянная
a.max_size() size_type-size() самого большого возможного контейнера. постоянная
a.empty() обратимый в bool a.size()==0-постоянная
a ‹ b обратимый в bool lexicographical_compare(a.begin(), a.end(), b.begin(), b.end())до: ‹ определён для значений T. ‹ - отношение полного упорядочения. lexicographical_compare определяется в разделе алгоритмов. линейная
a › b обратимый в bool b ‹ a-линейнaя
a ‹= b обратимый в bool!(a › b)-линейная
a ›= b обратимый в bool!(a ‹ b)-линейная
a.swap(b) void swap(a, b)-постоянная

Функция-член size() возвращает число элементов в контейнере. Её семантика определяется правилами конструкторов, вставок и удалений.

begin() возвращает итератор, ссылающийся на первый элемент в контейнере. end() возвращает итератор, который является законечным.

Перейти на страницу:

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных