首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用MPI_Bcast进行MPI通信

使用MPI_Bcast进行MPI通信
EN

Stack Overflow用户
提问于 2011-10-23 11:03:57
回答 1查看 73.7K关注 0票数 79

我尝试使用MPI_Bcast从根节点向所有其他节点广播一条消息。然而,每当我运行这个程序时,它总是在开始时挂起。有人知道它出了什么问题吗?

代码语言:javascript
复制
#include <mpi.h>
#include <stdio.h>

int main(int argc, char** argv) {
        int rank;
        int buf;
        MPI_Status status;
        MPI_Init(&argc, &argv);
        MPI_Comm_rank(MPI_COMM_WORLD, &rank);

        if(rank == 0) {
                buf = 777;
                MPI_Bcast(&buf, 1, MPI_INT, 0, MPI_COMM_WORLD);
        }
        else {
                MPI_Recv(&buf, 1, MPI_INT, 0, 0, MPI_COMM_WORLD, &status);
                printf("rank %d receiving received %d\n", rank, buf);
        }

        MPI_Finalize();
        return 0;
}
EN

回答 1

Stack Overflow用户

发布于 2016-08-19 23:34:47

MPI_Bcast是一个集合操作,它必须被所有进程调用才能完成。

并且在使用MPI_Bcast时不需要调用MPI_Recv。有一篇文章可能会对你有所帮助,click here

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7864075

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档