Procedura: conversione da contenitore STL/CLR a raccolta di .NET
Questo argomento illustra come convertire i contenitori STL/CLR nelle raccolte .NET equivalenti. Ad esempio, viene illustrato come convertire un vettore STL/CLR in .NET ICollection<T> e come convertire una mappa STL/CLR in un file .NETIDictionary<TKey,TValue>, ma la procedura è simile per tutte le raccolte e i contenitori.
Per creare una raccolta da un contenitore
Usa uno dei seguenti metodi:
Per convertire parte di un contenitore, chiamare la funzione make_collection e passare l'iteratore di inizio e l'iteratore finale del contenitore STL/CLR da copiare nella raccolta .NET. Questo modello di funzione accetta un iteratore STL/CLR come argomento modello. Il primo esempio illustra questo metodo.
Per convertire un intero contenitore, eseguire il cast del contenitore in un'interfaccia o una raccolta di interfacce .NET appropriata. Il secondo esempio illustra questo metodo.
Esempi
In questo esempio viene creato un STL/CLR vector
e vengono aggiunti 5 elementi. Viene quindi creata una raccolta .NET chiamando la make_collection
funzione . Infine, viene visualizzato il contenuto della raccolta appena creata.
// 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);
}
}
The contents of the System::Collections::Generic::ICollection are:
3
5
7
In questo esempio viene creato un STL/CLR map
e vengono aggiunti 5 elementi. Viene quindi creato un file .NET IDictionary<TKey,TValue> e assegnato map
direttamente a esso. Infine, viene visualizzato il contenuto della raccolta appena creata.
// 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);
}
}
The contents of the IDictionary are:
Key: 0.00 Value: 0
Key: 13.00 Value: 13
Key: 22.00 Value: 22
Key: 42.00 Value: 42
Key: 74.00 Value: 74
Vedi anche
Riferimenti alla libreria STL/CLR
Procedura: Convertire da una raccolta .NET a un contenitore STL/CLR
range_adapter (STL/CLR)