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 值引用,而不会自行移动。
对 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 值引用,而不会自行移动。