Una soluzione alternativa fornita dalla libreria standard è:
std::array<B, some_constant_value>
arr((std::copy(init.begin(),init.end(),(&arr)->begin()),arr));
Nota che l'argomento del costruttore è racchiuso da ((...))
, in modo che esso venga analizzato correttamente come espressione di virgola anziché come due argomenti.
Questa soluzione si basa sul fatto che B
è implicitamente costruibile da A
. Una breve soluzione che funziona anche se il costruttore di conversione è reso esplicito è:
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));
Il seguente programma di test, costruita con GCC 4.7.2, clang 3.2 e Intel C++ 13.1.1, (opzioni -g -O0 -Wall -std=c++11
) illustra entrambe le soluzioni:
#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;
}
fonte
2013-04-29 09:04:38
Avete * bisogno * di inizializzazione o potete prendere la strada facile e fare un incarico? – Pubby
@Pubby Non posso eseguire il compito perché B non costruirà senza argomento, sfortunatamente. – Svalorzen