c++ - MPI 在 C++ 中发送具有 vector 属性的结构

标签 c++ vector struct mpi stdvector

我想发送一个具有 vector 属性的结构。

typedef struct {
    int id;
    vector<int> neighbors;
} Node;

我知道我必须创建一个 MPI 派生数据类型,如 this answer ,但我不知道在我的情况下该怎么做,因为我在结构中有一个 vector 。

最佳答案

如果你想保持高水平并发送对象,那么Boost.MPI是个不错的选择。使用 Boost.MPI,您可以为结构指定高级序列化。

您不能(正确地)静态确定 vector 数据成员的偏移量。拼凑出一个有效的类型当然是可能的。但这也是搬起石头砸自己脚的好方法。您会在代码中引入假设(例如, vector 大小不会改变),一旦违反就会产生细微的错误。因此,在那种情况下,在 MPI_Send 中单独发送 idneighbours::data() 对我来说似乎更干净,更不容易出错 -而不是使用不适合此用例的 MPI 类型。

关于c++ - MPI 在 C++ 中发送具有 vector 属性的结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36021305/

相关文章:

c++ - STL优先级队列的初始化

c++ - 异步事件 : already defined linker error [Windows Update API]

c++ - 为什么我的 vector 不能访问嵌套结构中的变量?

c++ - 队列实现的 Malloc 指针错误

c++ - 重命名两个目录中的文件名,如果它们之间的某些字符匹配 - vector 下标超出范围

go - 如何为谷歌自动生成的库初始化一个包含 slice 的结构

c - 带和不带结构名称的 Typedef

c - 处理结构中的字符串

c++ - 将函数指针传递给函数

c++ - 在 Windows cmd 提示符下工作时设置 NLOpt