我正在编写一个C程序,如下所示:
for (int i=0;i<n;i++){
[makes new file for i: i.txt]
[runs a long and intensive computation]
[writes to i.txt]
[closes i.txt]}其中n是一些大的数。显然,几个迭代一次可以并行运行,因为它们不相互依赖。我的处理器上有八个核,所以我似乎希望我的程序能在这八个核上分发迭代,所以它运行得越快。这意味着我希望程序是多线程的。
我的问题是,我是否需要在C中手动多线程这个进程,或者多线程是否在某种程度上自动完成。我和GCC一起编译,我知道GCC优化得很好,但我不知道它是否自动多线程。我也不知道我的操作系统(Debian )是否会自动将程序分发到我的处理器的所有八个核心上。如果没有,有什么方法可以让它不需要实际用C编写多线程代码就可以转到多线程上呢?
发布于 2014-02-04 21:37:11
如果你想要的话,你可以手动多线程,或者你可以使用库和工具来承担你想要的更多或更少的责任。OpenMP绝对值得一看。
发布于 2014-02-04 21:58:39
答案很简单: GCC本身并不会自动多线程。多线程是在严格高于C的层中定义的,所以GCC这样做是一种层次性的违反。
尽管如此,有许多库可以使工作变得更容易(而不是手动多线程处理您的特定案例是一项很大的工作),而且其中一些库在语言级别上集成得更紧密。OpenMP已经被其他人提到了。
发布于 2014-02-04 22:33:27
您还可以考虑在C11标准中添加有关多线程应用程序的新内容。
https://stackoverflow.com/questions/21563884
复制相似问题