Eine alternative Lösung der Standardbibliothek zur Verfügung gestellt ist:
std::array<B, some_constant_value>
arr((std::copy(init.begin(),init.end(),(&arr)->begin()),arr));
Beachten Sie, dass das Argument des Konstruktors wird von ((...))
eingeschlossen, so dass es korrekt als ein Komma-Ausdruck statt als zwei Argumente analysiert wird. Diese Lösung beruht auf der Tatsache, dass B
implizit von A
konstruierbar ist. Eine kurze Lösung, die auch funktioniert, wenn die Umwandlung Konstruktor explizit gemacht ist:
auto lamb =
[&init]() -> B { static size_t i = 0; return B(init[i++]); };
std::array<B, some_constant_value>
arr((std::generate((&arr)->begin(),(&arr)->end(),lamb),arr));
Das folgende Testprogramm, gebaut mit GCC 4.7.2, klirrte 3.2 und Intel C++ 13.1.1, (Optionen -g -O0 -Wall -std=c++11
) stellt beide Lösungen dar:
#include <iostream>
#include <array>
#include <algorithm>
struct A
{
int _i = 42;
};
struct B
{
B(A x)
: _i(x._i){}
int _i;
};
struct C
{
explicit C(A x)
: _i(x._i){}
int _i;
};
using namespace std;
int main()
{
array<A, 10> init;
array<B, 10> arr((copy(init.begin(),init.end(),(&arr)->begin()),arr));
cout << "arr contains..." << endl;
for (size_t i = 0; i < arr.size(); ++i) {
cout << arr[i]._i << endl;
}
auto lamb =
[&init]() -> C { static size_t i = 0; return C(init[i++]); };
array<C, 10> brr((generate((&brr)->begin(),(&brr)->end(),lamb),brr));
cout << "brr contains..." << endl;
for (size_t i = 0; i < brr.size(); ++i) {
cout << brr[i]._i << endl;
}
return 0;
}
Benötigen Sie * Initialisierung * oder können Sie die einfache Route nehmen und Aufgabe übernehmen? – Pubby
@Pubby Ich kann die Zuweisung nicht machen, weil B leider ohne Argument nicht konstruiert wird. – Svalorzen