allocator_typeget_allocator()constnoexcept;
Эффекты: Возвращает копию распределителя, которая была передана конструктору объекта.
Сложность: Постоянная.
stored_allocator_type&get_stored_allocator()noexcept;
Эффекты: Возвращает ссылку на внутренний распределитель.
Бросает: Ничто
Сложность: Константа.
Примечание: Нестандартное расширение.
conststored_allocator_type&get_stored_allocator()constnoexcept;
Эффекты: Возвращает ссылку на внутренний распределитель.
Бросает: Ничто
Сложность: Константа.
Примечание: Нестандартное расширение.
итераторначинаютбез исключения;
Эффекты: возвращает итератор к первому элементу, содержащемуся в контейнере.
Бросок: Ничего.
Сложность: Постоянная.
const_iteratorbegin()constnoexcept;
Эффекты: Возвращает const_iterator к первому элементу, содержащемуся в контейнере.
Бросает: Ничего.
Сложность: Постоянная.
iteratorend()noexcept;
Эффекты: Возвращает итератор в конец контейнера.
Бросает: Ничего.
Сложность: Постоянная.
const_iteratorend()constnoexcept;
Эффекты: Возвращает const_iterator в конец контейнера.
Бросок: Ничего.
Сложность: Постоянная.
reverse_iteratorrbegin()noexcept;
Эффекты: Возвращает обратный_iterator, указывающий на начало обратного контейнера.
Бросает: Ничего.
Сложность: Постоянная.
const_reverse_iteratorrbegin()constnoexcept;
Эффекты: Возвращает const_reverse_iterator, указывающий на начало обратного контейнера.
Бросок: Ничего.
Сложность: Постоянная.
reverse_iteratorrend()noexcept;
Эффекты: Возвращает обратный_iterator, указывающий на конец обратного контейнера.
Бросок: Ничего.
Сложность: Постоянная.
const_reverse_iteratorrend()constnoexcept;
Эффекты: Возвращает const_reverse_iterator, указывающий на конец обратного контейнера.
Бросок: Ничего.
Сложность: Постоянная.
const_iteratorcbegin()constnoexcept;
Эффекты: Возвращает const_iterator к первому элементу, содержащемуся в контейнере.
Бросает: Ничего.
Сложность: Постоянная.
const_iteratorcendconstno except;
: Возвращает const_iterator в конец контейнера.
Бросок: Ничего.
Сложность: Постоянно.
const_reverse_iteratorcrbegin()constnoexcept;
Эффекты: Возвращает const_reverse_iterator, указывающий на начало обратного контейнера.
Бросает: Ничего.
Сложность: Постоянная.
const_reverse_iteratorcrend()constnoexcept;
Эффекты: Возвращает const_reverse_iterator, указывающий на конец обратного контейнера.
Бросок: Ничего.
Сложность: Постоянно.
boolempty()constnoexcept;
Эффекты: Возвращается, если контейнер не содержит элементов.
Бросок: Ничего.
Сложность: Постоянная.
size_typesize()constnoexcept;
Эффекты: Возвращает количество элементов, содержащихся в контейнере.
Бросок: Ничего.
Сложность: Постоянная.
size_typemax_size()constnoexcept;
Эффекты: Возвращает максимально возможный размер контейнера.
Бросает: Ничего.
Сложность: Постоянная.
size_typecapacity()constnoexcept;
Эффекты: Количество элементов, для которых выделена память. Вместимость () всегда больше или равна размеру ().
Бросает: Ничего.
Сложность: Постоянная.
voidreserve(size_typecnt);
Эффекты: Если n меньше или равно емкости(), этот вызов не имеет эффекта. В противном случае это запрос на выделение дополнительной памяти. Если запрос является успешным, то емкость () больше или равна n; в противном случае емкость () не изменяется. В любом случае размер() не изменяется.
Бросок: Если выделение памяти бросает, или конструктор копий Т бросает.
Примечание: Если емкость () меньше "cnt", итераторы и ссылки на значения могут быть признаны недействительными.
voidshrink_to_fit();
Эффекты: Пытается разобраться с избытком созданной памятиБросок: Если отбрасывает выделение памяти, или отбрасывает конструктор копий Т.
Сложность: Линейный размер().
iteratornth(size_typen)noexcept;
Требуется: размер() >= n.
Эффекты: Возвращает итератор к n-му элементу от начала контейнера. Возвращает конец(), если n == размер().
Бросок: Ничего.
Сложность: Постоянная.
Примечание: Нестандартное расширение
const_iteratornth(size_typen)constnoexcept;
Требуется: размер() >= n.
Эффекты: Возвращает const_iterator к n-му элементу с начала контейнера. Возвращает конец(), если n == размер().
Бросок: Ничего.
Сложность: Постоянная.
Примечание: Нестандартное расширение
size_typeindex_of(iteratorp)noexcept;
Требуется: start()<= p<= end().
Эффекты: Возвращает индекс элемента, указанный p и размером(), если p == конец().
Бросок: Ничего.
Сложность: Константа.
Примечание: Нестандартное расширение
size_typeindex_of(const_iteratorp)constnoexcept;
Требуется: start()<= p<= end().
Эффекты: Возвращает индекс элемента, указываемого p и размером(), если p == конец().
Бросает: Ничего.
Сложность: Константа.
Примечание: Нестандартное расширение
template<class...Args>iteratoremplace(Args&&...args);
Эффекты: Вставляет объект типа T, построенный с помощью std::forward(args)... и возвращает итератор, указывающий на вновь вставленный элемент.
Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
template<class...Args>
iteratoremplace_hint(const_iteratorhint,Args&&...args);
Эффекты: Вставляет объект типа Т, построенный с помощью std::forward(args)... в контейнер. p - подсказка, указывающая, где вставка должна начать поиск.
Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x.
Сложность: Логарифмическое время поиска (постоянное время, если значение должно быть вставлено перед p) плюс линейная вставка к элементам с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
iteratorinsert(constvalue_type&x);
Эффекты: Вставляет x и возвращает итератор, указывающий на вновь вставленный элемент.
Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
iteratorinsert(value_type&&x);
Эффекты: Вставляет новое значение, построенное из x, и возвращает итератор, указывающий на вновь вставленный элемент.
Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
итераторвставитьimpl_value_type&&x;
Эффекты: Вставляет новое значение, построенное из x, и возвращает итератор, указывающий на вновь вставленный элемент.
Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
iteratorinsert(const_iteratorp,constvalue_type&x);
Эффекты: Вставьте копию x в контейнер. p - подсказка, указывающая, где вставка должна начать поиск.
Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x.
Сложность: Логарифмическое время поиска (постоянное время, если значение должно быть вставлено перед p) плюс линейная вставка к элементам с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
iteratorinsert(const_iteratorp,value_type&&x);
Эффекты: Вставляет движение значения, построенное из x в контейнере. p - подсказка, указывающая, где вставка должна начать поиск.
Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x.
Сложность: Логарифмическое время поиска (постоянное время, если значение должно быть вставлено перед p) плюс линейная вставка к элементам с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
итераторвставитьconst_iteratorp,impl_value_type&&x;
Эффекты: Вставляет движение значения, построенное из x в контейнере. p - подсказка, указывающая, где вставка должна начать поиск.
Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x.
Сложность: Логарифмическое время поиска (постоянное время, если значение должно быть вставлено перед p) плюс линейная вставка к элементам с большими клавишами, чем x.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
template<typenameInputIterator>
voidinsert(InputIteratorfirst,InputIteratorlast);
Требует: во-первых, последние не являются итераторами в *это.
Эффекты: вставляет каждый элемент из диапазона [первый, последний]
Сложность: Максимальное время поиска N log(size()+N) (N - расстояние от первого до последнего) плюс время вставки N*size().
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
template<typenameInputIterator>
voidinsert(ordered_range_t,InputIteratorfirst,InputIteratorlast);
Требует: первый, последний не являются итераторами в *это.
Требует: [первый, последний] должен быть упорядочен в соответствии с предикатом.
Эффекты: вставляет каждый элемент из диапазона [первый, последний], если и только если нет элемента с ключом, эквивалентным ключу этого элемента. Эта функция более эффективна, чем создание нормального диапазона для упорядоченных диапазонов.
Сложность: Максимально N log(size()+N) (N - расстояние от первого до последнего) время поиска плюс N*size() время вставки.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
Примечание: Нестандартное расширение.
voidinsert(std::initializer_list<value_type>il);
Эффекты: вставляет каждый элемент из диапазона [il.begin(), il.end()) .
Сложность: Максимально N log(size()+N) (N - расстояние от первого до последнего) время поиска плюс N*size() время вставки.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
voidinsert(ordered_range_t,std::initializer_list<value_type>il);
Требует: [il.begin(), il.end()) должен быть упорядочен в соответствии с предикатом.
Эффекты: вставляет каждый элемент из диапазона [il.begin(), il.end()) если и только если нет элемента с ключом, эквивалентным ключу этого элемента. Эта функция более эффективна, чем создание нормального диапазона для упорядоченных диапазонов.
Сложность: Максимально N log(size()+N) (N - расстояние от первого до последнего) время поиска плюс N*size() время вставки.
Примечание: Если элемент вставлен, это может сделать элементы недействительными.
Примечание: Нестандартное расширение.
template<typenameC2>
voidmerge(flat_multimap<Key,T,C2,Allocator>&source);
Требуется: это->get_allocator() == source.get_allocator().
Эффекты: Извлекает каждый элемент в источнике и вставляет его в объект сравнения *это.
Посткондиция: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник.
Бросок: Ничего, если объект сравнения не бросает.
Сложность: N log(a.size() + N) (N имеет значение source.size())
template<typenameC2>
voidmerge(flat_multimap<Key,T,C2,Allocator>&&source);
Требуется: это->get_allocator() == source.get_allocator().
Эффекты: Извлекает каждый элемент в источнике и вставляет его в объект сравнения *это.
Посткондиция: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник.
Бросок: Ничего, если объект сравнения не бросит.
Сложность: N log(a.size() + N) (N имеет значение source.size())
template<typenameC2>voidmerge(flat_map<Key,T,C2,Allocator>&source);
Требуется: это->get_allocator() == source.get_allocator().
Эффекты: Извлекает каждый элемент в источнике и вставляет его в объект сравнения *это.
Посткондиция: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник.
Бросок: Ничего, если объект сравнения не бросает.
Сложность: N log(a.size() + N) (N имеет значение source.size())
template<typenameC2>voidmerge(flat_map<Key,T,C2,Allocator>&&source);
Требуется:
Эффекты: Извлекает каждый элемент в источнике и вставляет его в объект сравнения *это.
Посткондиция: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник.
Бросок: Ничего, если объект сравнения не бросит.
Сложность: N log(a.size() + N) (N имеет значение source.size())
iteratorerase(const_iteratorp);
Эффекты: Стирает элемент, на который указывает p.
Возвращает: Возвращает итератор, указывающий на элемент непосредственно после q перед стиранием элемента. Если такого элемента не существует, возвращается конец ().
Сложность: Линейные к элементам с ключами больше, чем p
Примечание: Инвалидирует элементы ключами не меньше, чем стертый элемент.
size_typeerase(constkey_type&x);
Эффекты: Стирает все элементы в контейнере с ключом, эквивалентным x.
Возвращает: Возвращает число стертых элементов.
Сложность: Логарифмическое время поиска плюс время стирания линейно элементам с большими клавишами.
iteratorerase(const_iteratorfirst,const_iteratorlast);
Эффекты: Стирает все элементы в диапазоне [первый, последний].
Возвращение: Возвращается последним.
Сложность: размер()*N, где N — расстояние от первого до последнего.
Сложность: Логарифмическое время поиска плюс время стирания линейно элементам с большими клавишами.
voidswap(flat_multimap&x)noexcept(allocator_traits_type::is_always_equal::value&&boost::container::container_detail::is_nothrow_swappable<Compare>::value));
Эффекты: Измените содержание *это и x.
Бросает: Ничего.
Сложность: Константа.
voidclear()noexcept;
Эффекты: стирание (a.begin(),a.end()).
Посткондиция: размер() == 0.
Сложность: линейный размер().
key_comparekey_comp()const;
Эффекты: Возвращает объект сравнения, из которого был построен объект сравнения.
Сложность: Константа.
value_comparevalue_comp()const;
Эффекты: Возвращает объект value_compare, построенный из объекта сравнения.
Сложность: Постоянная.
iteratorfind(constkey_type&x);
Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным x, или конец(), если такой элемент не найден.
Сложность: Логарифмический.
const_iteratorfindconstkey_type&x]const;
Returns: Const_iterator, указывающий на элемент с ключом, эквивалентным x, или конец(), если такой элемент не найден.
Сложность: Логарифмический.
size_typecount(constkey_type&x)const;
Возвращение: Число элементов с ключом, эквивалентным x.
Сложность: log(size())+count(k)
iteratorlower_bound(constkey_type&x);
Возвращение: Итератор, указывающий на первый элемент ключом не менее k, или a.end(), если такой элемент не найден.
Сложность: Логарифмический
const_iteratorlower_boundconstkey_type&x]const;
Возвращение: Конст-итератор, указывающий на первый элемент с ключом не менее k, или a.end(), если такой элемент не найден.
Сложность: Логарифмический
iteratorupper_bound(constkey_type&x);
Возвращение: Итератор, указывающий на первый элемент с ключом не менее x, или конец(), если такой элемент не найден.
Сложность: Логарифмический
const_iteratorupper_boundconstkey_type&x]const;
Возвращение: Конст-итератор, указывающий на первый элемент с ключом не менее x, или конец(), если такой элемент не найден.
Сложность: Логарифмический
std::pair<iterator,iterator>equal_range(constkey_type&x);
Эффекты: Эквивалент std::make_pair(this->lower_bound(k), this->upper_bound(k)).
Сложность: Логарифмический
std::pair<const_iterator,const_iterator>equal_rangeconst&const;
Эффекты: Эквивалент std::make_pair(this->lower_bound(k), this->upper_bound(k)).
Сложность: Логарифмический