¿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?

Respuestas a la pregunta(3)

Su respuesta a la pregunta