Поделиться через


hash_set::hash_set (STL/CLR)

Создает объект контейнера.

    hash_set();
    explicit hash_set(key_compare^ pred);
    hash_set(key_compare^ pred, hasher^ hashfn);
    hash_set(hash_set<Key>% right);
    hash_set(hash_set<Key>^ right);
    template<typename InIter>
        hash_sethash_set(InIter first, InIter last);
    template<typename InIter>
        hash_set(InIter first, InIter last,
            key_compare^ pred);
    template<typename InIter>
        hash_set(InIter first, InIter last,
            key_compare^ pred, hasher^ hashfn);
    hash_set(System::Collections::Generic::IEnumerable<GValue>^ right);
    hash_set(System::Collections::Generic::IEnumerable<GValue>^ right,
        key_compare^ pred);
    hash_set(System::Collections::Generic::IEnumerable<GValue>^ right,
        key_compare^ pred, hasher^ hashfn);

Параметры

  • first
    Начало диапазона, который необходимо вставить.

  • hashfn
    Хэш-функции для сопоставления клавиш к контейнерам.

  • last
    Элемент диапазона, который необходимо вставить.

  • pred
    Предикат для упорядочения управляемой последовательности.

  • правый
    Объект или диапазон для вставки.

Заметки

Конструктор:

hash_set();

инициализирует управляемую последовательность элементов, без упорядочения предиката по умолчанию key_compare() и отключен по умолчанию хэш-функцию.Используется для указания пустую initial управляемой последовательности с предикатом по умолчанию упорядочение и хэш-функцию.

Конструктор:

explicit hash_set(key_compare^ pred);

инициализирует управляемую последовательность без упорядочения элементов с pred и предиката по умолчанию хэш-функцию.Используется для указания начальной нулевой длины управляемой последовательности с указанным ключом и предиката по умолчанию хэш-функцию.

Конструктор:

hash_set(key_compare^ pred, hasher^ hashfn);

инициализирует управляемую последовательность без элементов, с pred упорядочения предиката с помощью хэш-функции hashfn.Используется для указания пустую initial управляемой последовательности с заданным предикатом упорядочения и хэш-функцию.

Конструктор:

hash_set(hash_set<Key>% right);

инициализирует управляемую последовательность последовательностью [right.hash_set::begin (STL/CLR)(),right.hash_set::end (STL/CLR)()) и упорядочения по умолчанию предиката, и отключен по умолчанию хэш-функцию.Используется для указания начальной управляемой последовательности, отслеживаемой объектом right копию последовательности hash_set с предикатом по умолчанию упорядочение и хэш-функцию.

Конструктор:

hash_set(hash_set<Key>^ right);

инициализирует управляемую последовательность последовательностью [right->hash_set::begin (STL/CLR)(),right->hash_set::end (STL/CLR)()) и упорядочения по умолчанию предиката, и отключен по умолчанию хэш-функцию.Используется для указания начальной управляемой последовательности, отслеживаемой объектом right копию последовательности hash_set с предикатом по умолчанию упорядочение и хэш-функцию.

Конструктор:

template<typename InIter>

hash_set(InIter first, InIter last);

инициализирует управляемую последовательность последовательностью [first,last) и упорядочения по умолчанию предиката, и отключен по умолчанию хэш-функцию.Используется для создания управляемой последовательности копию другой последовательности и упорядочения предиката по умолчанию и хэш-функцию.

Конструктор:

template<typename InIter>

hash_set(InIter first, InIter last,

key_compare^ pred);

инициализирует управляемую последовательность последовательностью [first,last) с предикатом упорядочения pred и отключен по умолчанию хэш-функцию.Используется для создания управляемой последовательности копию другой последовательности с указанным ключом и предиката по умолчанию хэш-функцию.

Конструктор:

template<typename InIter>

hash_set(InIter first, InIter last,

key_compare^ pred, hasher^ hashfn);

инициализирует управляемую последовательность последовательностью [first,last) с предикатом pred упорядочение с помощью хэш-функции hashfn.Используется для создания управляемой последовательности копию другой последовательности, с заданным предикатом упорядочения и хэш-функцию.

Конструктор:

hash_set(System::Collections::Generic::IEnumerable<Key>^ right);

инициализирует управляемую последовательность, последовательность с надписью right с перечислителем по умолчанию порядок предиката, и отключен по умолчанию хэш-функцию.Используется для создания управляемой последовательности копию другой последовательности, описанной перечислителем по умолчанию упорядочение предиката и хэш-функцию.

Конструктор:

hash_set(System::Collections::Generic::IEnumerable<Key>^ right,

key_compare^ pred);

инициализирует управляемую последовательность, последовательность с надписью перечислителем right с предикатом упорядочения pred и отключен по умолчанию хэш-функцию.Используется для создания управляемой последовательности копию другой последовательности, описанной перечислителем с заданным предикатом упорядочения и хэш-функции значения по умолчанию.

Конструктор:

hash_set(System::Collections::Generic::IEnumerable<Key>^ right,

key_compare^ pred, hasher^ hashfn);

инициализирует управляемую последовательность, последовательность с надписью перечислителем right с предикатом pred упорядочение с помощью хэш-функции hashfn.Используется для создания управляемой последовательности копию другой последовательности, описанной перечислителем с заданным предикатом упорядочения и хэш-функцию.

Пример

// cliext_hash_set_construct.cpp 
// compile with: /clr 
#include <cliext/hash_set> 
 
int myfun(wchar_t key) 
    { // hash a key 
    return (key ^ 0xdeadbeef); 
    } 
 
typedef cliext::hash_set<wchar_t> Myhash_set; 
int main() 
    { 
// construct an empty container 
    Myhash_set c1; 
    System::Console::WriteLine("size() = {0}", c1.size()); 
 
    c1.insert(L'a'); 
    c1.insert(L'b'); 
    c1.insert(L'c'); 
    for each (wchar_t elem in c1) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an ordering rule 
    Myhash_set c2 = cliext::greater_equal<wchar_t>(); 
    System::Console::WriteLine("size() = {0}", c2.size()); 
 
    c2.insert(c1.begin(), c1.end()); 
    for each (wchar_t elem in c2) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an ordering rule and hash function 
    Myhash_set c2h(cliext::greater_equal<wchar_t>(), 
        gcnew Myhash_set::hasher(&myfun)); 
    System::Console::WriteLine("size() = {0}", c2h.size()); 
 
    c2h.insert(c1.begin(), c1.end()); 
    for each (wchar_t elem in c2h) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
    System::Console::WriteLine(); 
 
// construct with an iterator range 
    Myhash_set c3(c1.begin(), c1.end()); 
    for each (wchar_t elem in c3) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an iterator range and an ordering rule 
    Myhash_set c4(c1.begin(), c1.end(), 
        cliext::greater_equal<wchar_t>()); 
    for each (wchar_t elem in c4) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an iterator range and an ordering rule and hash function 
    Myhash_set c4h(c1.begin(), c1.end(), 
        cliext::greater_equal<wchar_t>(), 
        gcnew Myhash_set::hasher(&myfun)); 
    for each (wchar_t elem in c4h) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
    System::Console::WriteLine(); 
 
// construct with an enumeration 
    Myhash_set c5(   // NOTE: cast is not needed 
        (System::Collections::Generic::IEnumerable<wchar_t>^)%c3); 
    for each (wchar_t elem in c5) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an enumeration and an ordering rule 
    Myhash_set c6(   // NOTE: cast is not needed 
        (System::Collections::Generic::IEnumerable<wchar_t>^)%c3, 
            cliext::greater_equal<wchar_t>()); 
    for each (wchar_t elem in c6) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an enumeration and an ordering rule and hash function 
    Myhash_set c6h(   // NOTE: cast is not needed 
        (System::Collections::Generic::IEnumerable<wchar_t>^)%c3, 
            cliext::greater_equal<wchar_t>(), 
                gcnew Myhash_set::hasher(&myfun)); 
    for each (wchar_t elem in c6h) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
    System::Console::WriteLine(); 
 
// construct from a generic container 
    Myhash_set c7(c4); 
    for each (wchar_t elem in c7) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct by copying another container 
    Myhash_set c8(%c3); 
    for each (wchar_t elem in c8) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
    return (0); 
    } 
 
  

Требования

заголовок: <cliext/hash_set>

Cliext пространство имен:

См. также

Ссылки

hash_set (STL/CLR)

hash_set::generic_container (STL/CLR)

hash_set::operator= (STL/CLR)