Freigeben über


Gewusst wie: Konvertiert von einem STL/CLR-Container zu einer .NET-Auflistung

In diesem Thema wird gezeigt, wie der STL/CLR-Container den entsprechenden .NET-Auflistungen konvertiert.Als Beispiel veranschaulichen wir an, wie ein STL/CLR Vektor für .NET ICollection<T> konvertiert und wie ein STL/CLR Zuordnung für .NET IDictionary<TKey, TValue> konvertiert, aber die Prozedur ist für alle Auflistungen und Containern vergleichbar.

So erstellen Sie eine Sammlung von einem Container

  • Verwenden Sie eine der folgenden Methoden:

    • Um einen Teil eines Containers konvertieren, die make_collection-Funktion aufrufen und den beginnens iterator und endet iterator des in die .NET-Auflistung zu kopierende STL/CLR-Containers übergeben.Diese Vorlagenfunktion nimmt einen STL/CLR-Iterator als Vorlagenargument.Im ersten Beispiel wird diese Methode.

    • Um einen gesamten Container zu konvertieren, wandeln Sie den Container in eine entsprechende .NET-Auflistungs Oberfläche oder einer Auflistung von Schnittstellen.Im zweiten Beispiel wird diese Methode.

Beispiel

In diesem Beispiel erstellen wir ein STL/CLR und fügen vector 5 Elemente hinzu.Anschließend erstellen Sie eine .NET-Auflistung, indem wir die make_collection-Funktion aufrufen.Schließlich veranschaulichen wir den Inhalt der neu erstellten Auflistung an.

// 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);
    }
}
  

In diesem Beispiel erstellen wir ein STL/CLR und fügen map 5 Elemente hinzu.Anschließend erstellen Sie .NET IDictionary<TKey, TValue>, und weisen map direkt dorthin zu.Schließlich veranschaulichen wir den Inhalt der neu erstellten Auflistung an.

// 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);
    }
}
  

Siehe auch

Aufgaben

Gewusst wie: Konvertieren Sie von einer .NET-Auflistung zu einem STL/CLR-Container

Referenz

range_adapter (STL/CLR)

Weitere Ressourcen

STL/CLR-Bibliotheksreferenz