Sdílet prostřednictvím


Jak: převod z kontejneru STL/CLR.NET kolekce

Toto téma ukazuje, jak převést na odpovídající kontejnery STL/CLR.NET kolekcí.Jako příklad můžeme ukázat, jak převést STL/CLR vector na.NET ICollection<T> a převodu STL/CLR mapy na.NET IDictionary<TKey, TValue>, ale postup je podobný pro všechny kolekce a kontejnery.

Vytvoření kolekce z kontejneru

  • Use one of the following methods: (Instalační program v počítači rozpoznal nástroje pro správu systému Windows 2000. Nástroje pro správu systému Windows 2000 nejsou kompatibilní s operačními systémy Windows Server 2003. Použijte jednu z následujících metod:)

    • Chcete-li převést část kontejner volání make_collection fungovat a předat iterační begin a end iterační kontejneru STL/CLR zkopírovány do.NET kolekce.Tato funkce šablony trvá iterace STL/CLR jako argument šablony.První příklad ukazuje tato metoda.

    • Chcete-li převést celý kontejner odevzdaných vhodného kontejneru.Rozhraní kolekce NET nebo sada rozhraní.Druhý příklad ukazuje tato metoda.

Příklad

V tomto příkladu vytvoříme STL/CLR vector a přidat do ní 5 prvky.Pak vytvořte jsme.NET kolekce voláním make_collection funkce.Nakonec jsme nově vytvořené kolekce obsah zobrazit.

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

V tomto příkladu vytvoříme STL/CLR map a přidat do ní 5 prvky.Pak vytvořte jsme.NET IDictionary<TKey, TValue> a přiřadit map k němu.Nakonec jsme nově vytvořené kolekce obsah zobrazit.

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

Viz také

Úkoly

Jak: převod z.NET kolekce STL/CLR kontejneru

Referenční dokumentace

range_adapter (STL/CLR)

Další zdroje

Reference knihovny STL/CLR