- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我感兴趣的是 OpenMPI 中是否有命令或技术来进行原子调用以写入 stdout(或者就此而言,任何流)。
我注意到,在 MPI 程序的执行过程中,写入 cout(或其他流)的调用可能会变得困惑,因为每个 proc 都可能在到达特定代码段时写入。报告结果时,一行可以被多个 proc 写入,混淆了问题。所以 2 个不同的过程可能会做这样的事情:
//Proc 10 - results calculated somewhere above
// result1 = 10
// result2 = 11
cout << "My results are: " << result1 << " " << resul2 << endl;
和:
//Proc 20 - results calculated somewhere above
// result1 = 20
// result2 = 21
cout << "My results are: " << result1 << " " << resul2 << endl;
但结果可能是:
My results are: 20 My results are: 10 11 21
我正在寻找的是类似于“阻塞”或原子 cout 的东西(以及可能写入其他流,例如文件流)。所以一旦我开始写一个 cout,它就会阻塞直到语句结束,或者直到发出 endl 或对流的刷新。如果是这样的话,我可以保证这两行是分开的(但是,当然,我仍然不知道哪一行先来):
My results are: 20 21
My results are: 10 11
最佳答案
使用标准 i/o 流(C 语言中的 stdout 和 stdin 或 C++ 中的 cout 和 cin)并不是 MPI 的最佳部分(OpenMPI 实现了 MPI)。有一些关于此的幻灯片:http://www.csee.wvu.edu/~donm/classes/cs591x/notes/io1.ppt Slide 10 有一个解决方案。(或“PS Pacheco 使用 Mpi 进行并行编程”一书的 chapter 8.1)
在 rank 0 的进程中使用 cout 执行所有 I/O。如果你想从其他进程输出一些数据,只需将包含此数据的 MPI 消息发送到 rank 0。
关于c++ - 在 MPI 中对 cout 的 "atomic"调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15901226/
我想知道 cout<
这可能是一个初学者问题,了解 cout 的工作原理可能是这里的关键。如果有人可以链接到一个好的解释,那就太好了。 cout(&cout) 的地址. cout << &cout打印出 cout 的地址.
经过一整天的编码,我不小心写了 cout << "some text" << cout; 代替 cout << "some text" << endl; 现在它打印出一个内存地址。它指向什么? 最佳答
这与 difference-between-cout-x-and-cout-operator-x 有关问题,但还是有点不同... #include int main(){ std::cout
我是 C++ 的新手,最近我花了几天时间阅读有关指针的内容。我意识到下面的 2 段代码给我不同的结果,尽管它们看起来相同。 第一段代码: int a = 5; int* ptr = &a; cout
我尝试使用更短的语法并避免在任何地方使用 std::,所以我开始使用新的别名语法。在一些例子中,我看到人们这样使用它: using json = nlohmann::json; 并尝试使用 std::
这是我的头文件 #ifndef KINGDOM_H_ #define KINGDOM_H_ #include using namespace std; namespace sict{ cla
我经常遇到要将二维数组打印到屏幕或文件的情况。我的标准方法是这样的: for(int q=0; q #include void printNumber(int x) { std::cout
有一些 cout 语句,但第一个 cout 语句末尾的空格出现在第二个 cout 语句的开头。这是代码: #include int main() { using namespace std;
我在搞乱代码时遇到了这种相当模糊的行为,这是示例: #include using namespace std; int print(void); int main(void) { cout
我收到所有 cout 和 endl 的这些错误消息: main.cc:17:5: error: ‘cout’ was not declared in this scope main.cc:17:5:
这个问题在这里已经有了答案: What is the meaning of prepended double colon "::"? (9 个回答) 关闭 7 个月前。 有一个简单的代码,包含::操
我有下面的代码,我不太明白为什么结果恰好像下面这样: #include #include using namespace std; int main () { std::stringstre
在 C++ 中,当我在 .h 文件中声明自己的命名空间时,如下所示: namespace my_own { //... } 那么,如果我在命名空间 my_own 内部或外部声明 using s
背景 IIRC,来自 Release 2.0 C++ 将单字符常量存储为类型 char而不是 int .但是在 Release 2.0 之前声明如下 cout #include using name
Problem was in IDE I am using - CLion 1.2.4 gives incorrect output inside its own output window, sol
我知道有几个这样的拷贝,但到目前为止,没有一个对我有用。我正在尝试使用 g++ 在 Ubuntu 上编译一个非常简单的 C++ 程序,但它给了我范围错误。 #include using namesp
我在这里有一个难题,我无法解决,也没有在网上找到正确的答案: 我创建了一个带有清理路由的分离线程,问题是在我的 Imac 和 Ubuntu 9.1(双核)上。我无法正确取消空闲代码中的分离线程: #i
#include #include #include using namespace std; int main() { ofstream fout("test.txt"); f
我是一名优秀的程序员,十分优秀!