我想发送一个具有vector属性的结构.
typedef struct {
int id;
vector<int> neighbors;
} Node;
我知道我必须像this answer一样创建一个MPI派生的数据类型,但我不知道如何在我的情况下这样做,我在结构中有一个向量.
最佳答案 如果你想保持高水平并发送物体,那么
Boost.MPI是个不错的选择.使用Boost.MPI,您可以为结构指定高级序列化.
您不能(正确)静态地确定向量的数据成员的偏移量.当然可以拼凑出一种有效的类型.但这也是射击自己的好方法.您将在代码中引入假设(例如,矢量大小不会改变),一旦违反将会产生微妙的错误.因此,在这种情况下,我只是简单地在MPI_Send中发送id和neighbors :: data()而不是使用不适合此用例的MPI类型,这似乎更简洁,更不容易出错.