¿Un constructor de plantilla anula el constructor de copia implícita en C ++?
¿Un constructor de plantilla (como el siguiente) anula el constructor de copia implícita?
template <class T>
struct Foo
{
T data;
// ...
template <class U>
Foo(const Foo<U> &other) : data((T)doSomethingWith(other.data)) {}
// ...
};
Si es así, ¿todavía lo anula siother
se pasa por valor en lugar de referencia constante?
Si es así, ¿hay alguna forma de evitar esto sin definir explícitamente un constructor de copia?