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

我正在尝试从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&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...