Значение копируется вместо перемещения.Зачем? - PullRequest
0 голосов
/ 03 июня 2018

Почему объявленные здесь объекты не перемещаются, а копируются вместо этого?Это как-то связано с копией elision?Разве текущий код не должен был изменить объекты класса?Первоначально предполагалось, что при использовании std :: move внутренности B будут изменены.Я что-то упустил?Есть ли обходной путь?

#include <iostream>
#include <algorithm>
#include <vector>

class A {
    public:
        A() {}
        auto&& get() { return v; }
        friend std::ostream& operator<<(std::ostream& o, A const& a) {
            o << "A: ";
            for (auto it = std::begin(a.v); it != std::end(a.v); ++it) { if (it != std::begin(a.v)) { o << " "; } o << *it; }
            return o;
        }
    private:
        std::vector<int> v;
};

class B {
    public:
        B() {};
        auto&& get() { return v; }
        friend std::ostream& operator<<(std::ostream& o, B const& b) {
            o << "B: { ";
            for (auto it = std::begin(b.v); it != std::end(b.v); ++it) { if (it != std::begin(b.v)) { o << " } { "; } o << *it; }
            return o << " }";
        }
    private:
        std::vector<A> v;
};

int main() {
    A a, a1, a2; B b;

    a.get().insert(a.get().end(), {1, 2, 3, 4});
    a1.get().insert(a1.get().end(), {5, 6, 7, 8});
    a2.get().insert(a2.get().end(), {9, 10, 11, 12});

    std::cout << a << "\n" << a1 <<  "\n" << a2;
    b.get().insert(b.get().end(), {a, a1, a2});
    std::cout << "\n" <<  b << "\n";

    a.get().push_back(std::move(b.get()[2].get()[2])); 

    std::cout << a << "\n" << a1 <<  "\n" << a2;
    std::cout << "\n" <<  b;
    return 0;
}

1 Ответ

0 голосов
/ 03 июня 2018

Вы звоните std::move на int.Для типов, не относящихся к классам, копирование и перемещение являются идентичными операциями.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...