C:信号代码:地址未映射(1)mpirecv
我用C语言编写了以下带有MPI的代码:C:信号代码:地址未映射(1)mpirecv,c,mpi,C,Mpi,我用C语言编写了以下带有MPI的代码: #include <mpi.h> #include <stdio.h> int main(int argc, char *argv[]) { int size, rank; MPI_Status status; int buf[1000]; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &size);
#include <mpi.h>
#include <stdio.h>
int main(int argc, char *argv[])
{
int size, rank;
MPI_Status status;
int buf[1000];
MPI_Init(&argc, &argv);
MPI_Comm_size(MPI_COMM_WORLD, &size);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
if (rank == 0) {
int i = 0;
while (i != 1000) {
buf[i] = i;
i++;
}
MPI_Send(buf, 999, MPI_INT, 1, 1, MPI_COMM_WORLD);
printf("msg has been sent\n");
}
if (rank == 1) {
int sz = sizeof(buf);
int lst = buf[sz-1];
MPI_Recv(buf, 999, MPI_INT, 0, 1, MPI_COMM_WORLD, &status);
printf("la taille du buf %d et dernier %d", sz, lst);
}
MPI_Finalize();
}
mpirun注意到在节点blitzkrieg上进程排名1,PID为3395- TravelMate-P253在信号11(分段故障)时退出
任何建议都会对thnx有所帮助。堆栈跟踪显示错误不在问题标题所示的
MPI\u Recv
中。错误实际上在这里:
int sz = sizeof(buf);
int lst = buf[sz-1]; // <---- here
您如何从堆栈跟踪中知道错误不在
MPI_Recv
中?@rasen58,因为堆栈跟踪中既不存在MPI_Recv
也不存在MPI库中的任何其他函数。
int sz = sizeof(buf);
int lst = buf[sz-1]; // <---- here
int sz = sizeof(buf) / sizeof(buf[0]);
int lst = buf[sz-1];