Я изучал возможности Move Constructors на С++, и мне было интересно, какие способы использовать эту функцию в пример, такой как ниже. Рассмотрим этот код:
template<unsigned int N>
class Foo {
public:
Foo() {
for (int i = 0; i < N; ++i) _nums[i] = 0;
}
Foo(const Foo<N>& other) {
for (int i = 0; i < N; ++i) _nums[i] = other._nums[i];
}
Foo(Foo<N>&& other) {
// ??? How can we take advantage of move constructors here?
}
// ... other methods and members
virtual ~Foo() { /* no action required */ }
private:
int _nums[N];
};
Foo<5> bar() {
Foo<5> result;
// Do stuff with 'result'
return result;
}
int main() {
Foo<5> foo(bar());
// ...
return 0;
}
В этом выше примере, если мы трассируем программу (с MSVС++ 2011), мы видим, что при построении foo
вызывается Foo<N>::Foo(Foo<N>&&)
, что является желаемым поведением. Однако, если бы у нас не было Foo<N>::Foo(Foo<N>&&)
, вместо него было бы вызвано Foo<N>::Foo(const Foo<N>&)
, что сделало бы операцию избыточной копии.
Мой вопрос, как отмечено в коде, с этим конкретным примером, который использует статически распределенный простой массив, есть ли способ использовать конструктор перемещения, чтобы избежать этой избыточной копии?