在多处理机上执行c++程序
Executing C++ program on multiple processor machine
出于研究目的,我用c++开发了一个程序。需要几天才能完成。
现在我在我们的实验室8核服务器机器上执行它以快速获得结果,但我看到机器只给我的程序分配了一个处理器,并且它仍然保持在13%的处理器使用率(即使我将进程优先级设置为高级别并且亲和性为8核)。
(这是一个简单的面向对象程序,没有任何并行性和多线程)
如何从强大的服务器机器中获得真正的好处?
将你的代码分割成可以并行执行的块。
你需要去读一下数据并行和任务并行。
那么您可以使用OpenMP或MPI
(它是一个简单的面向对象程序,没有任何并行性多线程)
如何从强大的服务器机器中获得真正的好处?
通过使用更多线程。无论计算机有多强大,它都不能在多个处理器上分配线程。找到程序的独立部分并并行运行它们。
- <
- c++ 0 x线程/gh><
- 提高线程/gh>
- OpenMP
我个人认为OpenMP是个玩具。
您必须通过将代码拆分为可以独立执行的多个任务,然后直接使用线程原语或更高级别的并行化框架(如OpenMP)来显式地利用多并行性。
如果您不想让您的程序本身使用多线程库或技术,您可以尝试将您的工作分解为几个独立的块。然后运行你的程序的多个副本…每个都被分配给不同的块,通过获取不同的命令行参数来指定。
至于总体上提高程序的性能…有一些分析工具可以帮助您加快速度或找到内存使用、I/O、CPU方面的瓶颈:
https://stackoverflow.com/questions/tagged/c%2b%2b%20profiling不会帮助你将工作分散到多个核心,但如果你能在一个算法中获得8倍的加速,那可能比多线程在8核上的帮助更大。再考虑一下。
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- C++,系统无法执行指定的程序
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到
- 重载操作程序时出错>>用于类中的字符串 memebr
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 试图在visual studio上用C++创建一个桌面应用程序
- 模板元程序查找相似的连续类型名称
- FFmpeg:制作一个应用程序比直接使用ffmepg更好吗
- 如何通过cpp程序运行shell脚本
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- IPC使用多个管道和分支进程来运行Python程序
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 基于boost的程序的静态链接——zlib问题
- 程序崩溃并显示"std::out_of_range"错误
- 在C应用程序中运行C++(带有STL)函数
- 使用mongocxx驱动程序时包含头文件问题
- 如何在c++程序中找到函数的地址