其他分享
首页 > 其他分享> > c-使用ppl.h查找最大值

c-使用ppl.h查找最大值

作者:互联网

在C的ppl库中是否有一个简单的函数,您可以在其中执行类似Concurrency :: max(vec)的操作,其中vec是数字的向量?我可以自己写,但我希望自己可以省下工作.

编辑:对不起,我可能还不够清楚.我需要max函数来利用并行化.

解决方法:

没有内置任何内容,但是使用可组合(减少变量)和并行循环(此处为parallel_for_each)很简单.但是,如果您正在做的工作只是数字的“最大值”,除非您正在看的数字量很大,那么可能很难看到加速.

您可以在msdn上阅读有关它的更多信息:

#include <ppl.h>
#include <climits>
#include <vector>
#include <numeric>
#include <iostream>
using namespace Concurrency;
int main(int argc, _TCHAR* argv[])
{
    std::vector<int> vec(10);
    std::iota( begin(vec), end(vec), 1);
    combinable<int> locals([]{ return INT_MIN; });
    parallel_for_each( begin(vec), end(vec), [&locals](int cur){
        auto & localMax = locals.local();
        localMax = std::max(cur, localMax);
    });
    std::cout << "max is " << locals.combine([](int left, int right){ return std::max<int>(left, right);}) << std::endl;
    return 0;
}

标签:ppl,c,max
来源: https://codeday.me/bug/20191011/1895908.html