24小时热门版块排行榜    

查看: 1233  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

von_weiqiang

木虫 (正式写手)

[求助] 用MPICH2运行并行程序,代码中的printf语句只有在所有进程都结束后才会打印出来么? 已有2人参与

能不能各进程一边运行,一边打印?
例如代码:
        MPI_Init(&argc, &argv);
        MPI_Comm_rank(MPI_COMM_WORLD,&myrank);
        for(i=0;i<1e1;i++)
        {
                a=integration(0,1,1e-6,f);
                printf("current %d %d %e\n",myrank,i,a);
        }
        MPI_Finalize();
其中,integration函数每调用一次需要约2s时间,每个进程运行时间大约20s,我的理解是,每个进程每2s就应该打印一次“进程号,循环次数”,所以进程号应该是杂乱无章的,可是用MPICH开启3个进程实际运行结果是这样:

current 0 0 3.141593e+000
current 0 1 3.141593e+000
current 0 2 3.141593e+000
current 0 3 3.141593e+000
current 0 4 3.141593e+000
current 0 5 3.141593e+000
current 0 6 3.141593e+000
current 0 7 3.141593e+000
current 0 8 3.141593e+000
current 0 9 3.141593e+000
current 2 0 3.141593e+000
current 2 1 3.141593e+000
current 2 2 3.141593e+000
current 2 3 3.141593e+000
current 2 4 3.141593e+000
current 2 5 3.141593e+000
current 2 6 3.141593e+000
current 2 7 3.141593e+000
current 2 8 3.141593e+000
current 2 9 3.141593e+000
current 1 0 3.141593e+000
current 1 1 3.141593e+000
current 1 2 3.141593e+000
current 1 3 3.141593e+000
current 1 4 3.141593e+000
current 1 5 3.141593e+000
current 1 6 3.141593e+000
current 1 7 3.141593e+000
current 1 8 3.141593e+000
current 1 9 3.141593e+000
请按任意键继续. . .

为什么呢?
回复此楼
专注传播负能量
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuejian0518

银虫 (初入文坛)

使用flush命令来刷新缓冲区, 你可以看到及时结果
4楼2014-02-13 14:14:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 von_weiqiang 的主题更新
信息提示
请填处理意见