unordered_multiset::unordered_multiset
Создает объект контейнера.
unordered_multiset(
const unordered_multiset& right);
explicit unordered_multiset(
size_type nbuckets = N0,
const Hash& hfn = Hash(),
const Pred& comp = Pred(),
const Alloc& al = Alloc());
template<class InIt>
unordered_multiset(
InIt first, InIt last,
size_type nbuckets = N0,
const Hash& hfn = Hash(),
const Pred& comp = Pred(),
const Alloc& al = Alloc());
unordered_multiset(
unordered_multiset&& right);
Параметры
Параметр |
Описание |
InIt |
Тип итератора. |
al |
Объект выделения в хранилище. |
comp |
Объект функции сравнения в хранилище. |
hfn |
Объект хэш-функция в хранилище. |
nbuckets |
Минимальное количество контейнеров. |
right |
Контейнер, в который выполняется копирование. |
Заметки
Первый конструктор задает копию последовательности управляемой by right.Второй конструктор задает пустую управляемой последовательности.Третий конструктор вставляет последовательность значений элементов [first, last).Четвертый конструктор задает копию последовательности, перемещая right.
Все конструкторы также инициализирующих несколько хранимых значений.Для конструктора копий значения получаются из right.В противном случае:
минимальное количество сегментов аргумент nbuckets, если он присутствует; в противном случае значение по умолчанию, описанное здесь как реализация-определенное значение N0.
объект хэш-функции аргумент hfn, если он присутствует; в противном случае он Hash().
объект функции сравнения аргумент comp, если он присутствует; в противном случае он Pred().
объект выделения аргумент al, если он присутствует; в противном случае он Alloc().
Пример
Код
// std_tr1__unordered_set__unordered_multiset_construct.cpp
// compile with: /EHsc
#include <unordered_set>
#include <iostream>
typedef std::unordered_multiset<char> Myset;
int main()
{
Myset c1;
c1.insert('a');
c1.insert('b');
c1.insert('c');
// display contents " [c] [b] [a]"
for (Myset::const_iterator it = c1.begin();
it != c1.end(); ++it)
std::cout << " [" << *it << "]";
std::cout << std::endl;
Myset c2(8,
std::hash<char>(),
std::equal_to<char>(),
std::allocator<std::pair<const char, int> >());
c2.insert('d');
c2.insert('e');
c2.insert('f');
// display contents " [f] [e] [d]"
for (Myset::const_iterator it = c2.begin();
it != c2.end(); ++it)
std::cout << " [" << *it << "]";
std::cout << std::endl;
Myset c3(c1.begin(),
c1.end(),
8,
std::hash<char>(),
std::equal_to<char>(),
std::allocator<std::pair<const char, int> >());
// display contents " [c] [b] [a]"
for (Myset::const_iterator it = c3.begin();
it != c3.end(); ++it)
std::cout << " [" << *it << "]";
std::cout << std::endl;
Myset c4(std::move(c3));
// display contents " [c] [b] [a]"
for (Myset::const_iterator it = c3.begin();
it != c3.end(); ++it)
std::cout << " [" << *it << "]";
std::cout << std::endl;
return (0);
}
Output
[c] [b] [a]
[f] [e] [d]
[c] [b] [a]
[c] [b] [a]
Требования
заголовок:<unordered_set>
пространство имен: STD