通过C中的引用传递std algos谓词

通过C中的引用传递std algos谓词,第1张

概述我正在尝试从std :: list中删除元素,并保留已删除元素的一些统计信息. 为了做到这一点,我从列表中使用remove_if函数,我有一个谓词.我想使用这个谓词来收集统计信息.以下是谓词的代码: class TestPredicate { private: int limit_; public: int sum; int count; TestPr 我正在尝试从std :: List中删除元素,并保留已删除元素的一些统计信息.

为了做到这一点,我从列表中使用remove_if函数,我有一个谓词.我想使用这个谓词来收集统计信息.以下是谓词的代码:

class TestPredicate  {  private:    int limit_;  public:    int sum;    int count;    TestPredicate(int limit) : limit_(limit),sum(0),count(0) {}    bool operator() (int value)     {      if (value >= limit_)      {        sum += value;        ++count;       // Part where I gather the stats        return true;      }      else        return false;    }  };

这里是algo的代码:

std::List < int > container;container.push_back(11);TestPredicate pred(10);container.remove_if(pred)assert(pred.count == 1);

不幸的是,断言是false,因为谓词是通过值传递的.有没有办法强迫它通过引用传递?

解决方法 传递参考包装器,可从< functional&gt ;::
container.remove_if(std::ref(pred));

如果您只有C 98/03但编译器有TR1,则可以使用< tr1 / functional>和std :: tr1 :: ref如果你对你的谓词做了一个小的修改:

#include <tr1/functional>class TestPredicate : public std::unary_function<int,bool>{                 //^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  // ...}container.remove_if(std::tr1::ref(pred));

如果一切都失败,那么您可以轻松地使用手动解决方案:

struct predref{  TestPredicate & p;  bool operator()(int n) { return p(n); }  predref(TestPredicate & r) : p(r) { }};container.remove_if(predref(pred));
总结

以上是内存溢出为你收集整理的通过C中的引用传递std algos谓词全部内容,希望文章能够帮你解决通过C中的引用传递std algos谓词所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1254967.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存