cv::parallel_for_ 的一个例子

重点:

  1. paralle_for_设置成n个线程,则实际只有n-1线程并行,第n个线程会等待其他线程运行结束后再执行,所以n=1和n=2实际上都是串行

cv::parallel_for_是opencv封装的一个多线程接口,利用这个接口可以方便实现多线程,不用考虑底层细节,以下是一个具体的例子

  1. 继承ParallelLoopBody,重载运算符()

class LoopBody : public cv::ParallelLoopBody
{
public:
    LoopBody (const std::vector<std::string>& filenames)
        : m_filenames(filenames)
    {
    }

    virtual void operator()(const cv::Range& r) const
    {
        for (int i = r.start; i != r.end; i++)  //遍历
        {
			std::cout << m_filenames[i] << std::endl;
                 
            //load image and to to sth
        }
    }

protected:
    const std::vector<std::string>& m_filenames;    
};

  1. 启动循环
		LoopBody body(filenames);
		cv::parallel_for_(cv::Range(0, static_cast<int>(filenames.size())), body); //启动
  1. 控制线成数目
    以前还有一个cv::parallel_for() 函数(不是以下划线结束)是单线程,就相当于for循环,但新版本的opencv里没有找个函数了,那么如果利用cv::parallel_for_()实现单线成的for循环?答案是把线程数设置成1
cv::setNumThreads(1);
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值