Udostępnij za pośrednictwem


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

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

Aby utworzyć kolekcję z kontenera

  • Użyj jednej z następujących metod:

    • Aby przekonwertować częścią kontenera, wywołanie make_collection funkcjonować i przekazać sterująca początkowy i koniec sterująca kontenera STL/CLR mają być kopiowane do kolekcji .NET.Ta funkcja szablon pobiera iterację STL/CLR jako argumentu szablon.W pierwszym przykładzie zademonstrowano tę metodę.

    • Aby przekonwertować cały pojemnik, oddanych kontenera na odpowiedni interfejs kolekcji .NET lub interfejs kolekcji.W drugim przykładzie zademonstrowano tę metodę.

Przykład

W tym przykładzie tworzymy STL/CLR vector i dodać do niego 5 elementów.Następnie możemy utworzyć kolekcję .NET poprzez wywołanie make_collection funkcji.Wreszcie możemy wyświetlić zawartość nowoutworzonych kolekcji.

// cliext_convert_vector_to_icollection.cpp
// compile with: /clr

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

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

int main(array<System::String ^> ^args)
{
    cliext::vector<int> primeNumbersCont;
    primeNumbersCont.push_back(2);
    primeNumbersCont.push_back(3);
    primeNumbersCont.push_back(5);
    primeNumbersCont.push_back(7);
    primeNumbersCont.push_back(11);

    System::Collections::Generic::ICollection<int> ^iColl =
        make_collection<cliext::vector<int>::iterator>(
            primeNumbersCont.begin() + 1,
            primeNumbersCont.end() - 1);

    Console::WriteLine("The contents of the System::Collections::Generic::ICollection are:");
    for each (int i in iColl)
    {
        Console::WriteLine(i);
    }
}
  

W tym przykładzie tworzymy STL/CLR map i dodać do niego 5 elementów.Następnie tworzymy .NET IDictionary i przypisać map bezpośrednio do niego.Wreszcie możemy wyświetlić zawartość nowoutworzonych kolekcji.

// cliext_convert_map_to_idictionary.cpp
// compile with: /clr

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

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

int main(array<System::String ^> ^args)
{
    cliext::map<float, int> ^aMap = gcnew cliext::map<float, int>;
    aMap->insert(cliext::make_pair<float, int>(42.0, 42));
    aMap->insert(cliext::make_pair<float, int>(13.0, 13));
    aMap->insert(cliext::make_pair<float, int>(74.0, 74));
    aMap->insert(cliext::make_pair<float, int>(22.0, 22));
    aMap->insert(cliext::make_pair<float, int>(0.0, 0));

    System::Collections::Generic::IDictionary<float, int> ^iDict = aMap;

    Console::WriteLine("The contents of the IDictionary are:");
    for each (KeyValuePair<float, int> ^kvp in iDict)
    {
        Console::WriteLine("Key: {0:F} Value: {1}", kvp->Key, kvp->Value);
    }
}
  

Zobacz też

Zadania

Porady: konwertowanie kolekcji .NET na kontener STL/CLR

Informacje

range_adapter (STL/CLR)

Inne zasoby

Odwołanie do biblioteki STL/CLR