c++ - 分段错误:C++ 中的结构序列化和 MPI 数据传输
问题描述
我正在尝试将序列化结构从一个等级发送到另一个等级。结果是
分段错误:11
我不知道它来自哪里。
我试图通过打印出一些值来定位问题,并且代码总是在MPI_Send
and之间中断MPI_Recv
,但是由于它是分段错误,因此无法确定它是问题的根源。请赐教。
int N = 11;
struct tests{
int number;
double *fx;
};
void locateMemoryTests(struct tests *t){
t->fx = (double*) malloc(N*sizeof(double));
}
void he(struct tests *t, int N){
int NRank, MyRank;
MPI_Comm_rank( MPI_COMM_WORLD, &MyRank );
MPI_Comm_size( MPI_COMM_WORLD, &NRank );
int st = MyRank * int(N/2);
int en = (MyRank+1) * int(N/2) + (N%2)*MyRank;
for (int i=st; i<en; i++){
t->fx[i] = i*i + 5*(i + t->number);
}
const int nitems = 2;
int blocklengths[2] = {1, N};
MPI_Datatype types[2] = {MPI_INT, MPI_DOUBLE};
MPI_Datatype mpi_tests_type;
MPI_Aint offsets[2];
offsets[0] = offsetof(tests, number);
offsets[1] = offsetof(tests, fx);
MPI_Type_create_struct(nitems, blocklengths, offsets, types, &mpi_tests_type);
MPI_Type_commit(&mpi_tests_type);
MPI_Comm_rank(MPI_COMM_WORLD, &MyRank);
if (MyRank == 0){
struct tests send;
send.number = t->number;
locateMemoryTests(&send);
for (int i=0; i<N; i++){
send.fx[i] = t->fx[i];
}
MPI_Send(&send, 2, mpi_tests_type, 1, 111, MPI_COMM_WORLD);
}
else if (MyRank == 1){
MPI_Status status;
struct tests recv;
locateMemoryTests(&recv);
MPI_Recv(&recv, 2, mpi_tests_type, 0, 111, MPI_COMM_WORLD, &status);
MPI_Type_free(&mpi_tests_type);
}
int main( int argc, char *argv[] ){
int NRank, MyRank;
MPI_Init( &argc, &argv );
MPI_Comm_rank( MPI_COMM_WORLD, &MyRank );
MPI_Comm_size( MPI_COMM_WORLD, &NRank );
struct tests tt;
tt.number = 5;
locateMemoryTests(&tt);
he(&tt,N);
MPI_Finalize();
return 0;
}
解决方案
您的 MPI 派生数据类型描述了以下 Cstruct
struct tests{
int number;
double fx[N];
};
但你使用的是不同的
struct tests{
int number;
double *fx;
};
如果N
不是常量,您可以声明
struct tests{
int number;
double fx[];
};
正确分配这样的struct
.
另一种选择是保持相同的定义,并struct
手动将数据传入/传出临时缓冲区。MPI_Pack()
MPI_Unpack()
推荐阅读
- python - Python,ML 错误:Series 的真值不明确。使用 a.empty、a.bool()、a.item()、a.any() 或 a.all()
- php - 如何更新laravel中的数据-数据中有数组值
- android - 从 Firebase 性能库测量时,graph.facebook.com 的成功率非常低
- html - 如何在 ng-repeat 中切换当前的“活动”类 div 并删除兄弟 div 的“活动”类
- r - 老鼠在 nnet.default 中返回错误:权重过多
- html - 如何将 HTML 转换为格式化的 Text,使间距、表格边框、元素定位等布局保持不变?
- javascript - 为什么通过 https 加载都无法从 chrome 中的 iframe 进行 Web 推送?
- maven - maven gmavenplus-plugin groovy 语法问题
- javascript - 我可以在另一个已解决的 Promise 中解决一个 Promise 吗?
- angular - Angular Reactive Forms - 创建一个返回数组作为值的组件