首页 > 解决方案 > MPI_Bcast c++ STL 向量

问题描述

为什么下面的代码不起作用?它适用于我的用户定义类,但不适用于 STL 向量。

std::vector<int> v(4);
MPI_Bcast(&v, sizeof(v), MPI_BYTE, 0, MPI_COMM_WORLD);

我收到分段错误:

[sdg:13611] Signal: Segmentation fault (11)
[sdg:13611] Signal code: Address not mapped (1)

由于vector中的元素是连续存储的,为什么我不能使用MPI_BYTE将std::vector作为一个整体发送?

标签: c++parallel-processingstlmpi

解决方案


vectora本身的地址与它的 不同data。像您提议的那样发送对象仅适用于可简单复制的类型 - 您可以想象 MPI 通信的工作方式类似于memcpy. 您可以检查std::is_trivially_copyable-std::vector本身绝不是可复制的。

但是,vector将其存储data在连续的内存中 - 您可以在其中使用memcpy.

您必须确保所有 MPI 进程在操作之前都有一个相同的向量sizecapacity还不够。如果您只知道size一个进程,则必须相应地在另一个进程上广播之前的大小和resize目标向量。

此外,向量中的元素本身必须是可简单复制的。

MPI_Bcast(v.data(), v.size(), MPI_INT, 0, MPI_COMM_WORLD);

如果由于某种原因您无法确定 MPI 类型(例如MPI_INT),您可以按如下方式进行(避免在更改类型时中断的冗余)。

MPI_Bcast(v.data(), v.size() * sizeof(decltype(v)::value_type)), MPI_BYTE, 0, MPI_COMM_WORLD);

推荐阅读