Udostępnij za pośrednictwem


Porady: konwertowanie kolekcji .NET na kontener STL/CLR

W tym temacie opisano sposób konwertowania kolekcje .NET do ich równoważnych kontenerów STL/CLR.Na przykład pokażemy jak konwertować .NET List do STL/CLR wektor i jak konwertować .NET Dictionary do STL/CLR mapy, ale procedura jest podobna dla wszystkich zbiorów i pojemniki.

Aby utworzyć kontener z kolekcji

  • Aby przekształcić całą kolekcję, utworzyć kontener STL/CLR i przekazać kolekcji do konstruktora.

    W pierwszym przykładzie zademonstrowano tę procedurę.

-LUB-

  1. Utworzyć rodzajowy kontenera STL/CLR, tworząc collection_adapter obiektu.Ta klasa szablon wykorzystuje interfejs kolekcji .NET jako argument.Aby sprawdzić, które interfejsy są obsługiwane, zobacz collection_adapter (STL/CLR).

  2. Skopiuj zawartość kolekcji .NET do kontenera.Można to zrobić za pomocą STL/CLR algorytm, lub przez iteracji kolekcji .NET i wstawianie kopię każdego elementu w kontenerze STL/CLR.

    W drugim przykładzie zademonstrowano tę procedurę.

Przykład

W tym przykładzie tworzymy rodzajowego List i dodać do niego 5 elementów.Następnie tworzymy vector za pomocą konstruktora, który zajmuje IEnumerable jako argument.

// cliext_convert_list_to_vector.cpp
// compile with: /clr

#include <cliext/adapter>
#include <cliext/algorithm>
#include <cliext/vector>

using namespace System;
using namespace System::Collections;
using namespace System::Collections::Generic;

int main(array<System::String ^> ^args)
{
    List<int> ^primeNumbersColl = gcnew List<int>();
    primeNumbersColl->Add(2);
    primeNumbersColl->Add(3);
    primeNumbersColl->Add(5);
    primeNumbersColl->Add(7);
    primeNumbersColl->Add(11);

    cliext::vector<int> ^primeNumbersCont =
        gcnew cliext::vector<int>(primeNumbersColl);

    Console::WriteLine("The contents of the cliext::vector are:");
    cliext::vector<int>::const_iterator it;
    for (it = primeNumbersCont->begin(); it != primeNumbersCont->end(); it++)
    {
        Console::WriteLine(*it);
    }
}
  

W tym przykładzie tworzymy rodzajowego Dictionary i dodać do niego 5 elementów.Następnie tworzymy collection_adapter na zawijanie Dictionary jako prosty kontener STL/CLR.Wreszcie, możemy stworzyć map i skopiować zawartość Dictionary do map przez Iterowanie nad collection_adapter.Podczas tego procesu, możemy utworzyć nową parę za pomocą make_pair funkcjonować i wstawić nową parę bezpośrednio do map.

// cliext_convert_dictionary_to_map.cpp
// compile with: /clr

#include <cliext/adapter>
#include <cliext/algorithm>
#include <cliext/map>

using namespace System;
using namespace System::Collections;
using namespace System::Collections::Generic;

int main(array<System::String ^> ^args)
{
    System::Collections::Generic::Dictionary<float, int> ^dict =
        gcnew System::Collections::Generic::Dictionary<float, int>();
    dict->Add(42.0, 42);
    dict->Add(13.0, 13);
    dict->Add(74.0, 74);
    dict->Add(22.0, 22);
    dict->Add(0.0, 0);

    cliext::collection_adapter<System::Collections::Generic::IDictionary<float, int>> dictAdapter(dict);
    cliext::map<float, int> aMap;
    for each (KeyValuePair<float, int> ^kvp in dictAdapter)
    {
        cliext::pair<float, int> aPair = cliext::make_pair(kvp->Key, kvp->Value);
        aMap.insert(aPair);
    }

    Console::WriteLine("The contents of the cliext::map are:");
    cliext::map<float, int>::const_iterator it;
    for (it = aMap.begin(); it != aMap.end(); it++)
    {
        Console::WriteLine("Key: {0:F} Value: {1}", it->first, it->second);
    }
}
  

Zobacz też

Zadania

Porady: konwertowanie kontenera STL/CLR na kolekcję .NET

Informacje

adapter (STL/CLR)

Inne zasoby

Odwołanie do biblioteki STL/CLR