为了做到这一点,我从列表中使用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> ;::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谓词所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)