MPI 和移动语义

MPI and move semantics

对 MPI 对象使用 C++11 移动语义有多安全?

让我们考虑一个小例子:

#include <mpi.h>
#include <iostream>

int main() {
    MPI_Init(nullptr, nullptr);

    int rank;
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);

    if (rank == 0) {
        // create info object and set a key value pair
        MPI_Info info;
        MPI_Info_create(&info);
        MPI_Info_set(info, "key", "value");

        int size;
        MPI_Info_get_nkeys(info, &size);
        std::cout << "size: " << size << std::endl;

        // move into new object
        MPI_Info info2 = std::move(info);
        MPI_Info_set(info2, "kex2", "value2");

        MPI_Info_get_nkeys(info2, &size);
        std::cout << "size: " << size << std::endl;
    }

    MPI_Finalize();
}

移动施工安全吗? IE。这样的移动操作是在 MPI 对象上定义的还是未定义的行为?

类型要么实现移动,要么不实现,在这种情况下,移动不过是复制。试图移动不动的东西不是未定义的行为。

请记住,单独 std::move 仅转换为 r 值引用,而不会自行移动。