如何使用提升范围将自定义迭代器封装在函数中
How to encapsulate custom iterator in function using boost-range
最近我使用boost-range
在满足某些条件的元素上创建范围。在所有情况下,我一直使用相同的过滤范围,因此我试图将此行为封装在外部函数中。
这就是我的问题开始的地方。请考虑以下示例。
#include <boost/range/adaptor/filtered.hpp>
#include <iostream>
#include <vector>
auto myFilter = [](const std::vector<int>& v, int r) {
return v | boost::adaptors::filtered([&r](auto v) { return v%r == 0; });
};
int main(int argc, const char* argv[])
{
using namespace boost::adaptors;
std::vector<int> input{ 1, 2, 3, 4, 5, 6, 7, 8, 9 };
for (auto& element : input | filtered([](auto v) {return v % 2 == 0; } ))
{
std::cout << "Element = " << element << std::endl;
}
std::cout << std::endl;
for (auto& element : myFilter(input,4))
{
std::cout << "Element = " << element << std::endl;
}
return 0;
}
第一个 for 循环的行为与预期的打印 4 和 8 相同。然而,第二个 for 循环只打印 4。为什么?
我的第二个想法是实现一个具有begin()
和end()
函数的类。这应该是范围对象周围的薄包装器。
这是在摆弄范围迭代器类型后的解决方案。
struct MyFilter {
MyFilter(const std::vector<int>& c, int r) : c(c), r(r), f([&r](auto v) { return v%r == 0; }) {
}
boost::range_detail::filtered_range<std::function<bool(int)>, std::vector<int>>::iterator begin() {
return rng.begin();
}
boost::range_detail::filtered_range<std::function<bool(int)>, std::vector<int>>::iterator end() {
return rng.end();
}
std::vector<int> c;
int r;
std::function<bool(int)> f;
boost::range_detail::filtered_range < std::function<bool(int)>, std::vector<int>> rng=c | boost::adaptors::filtered(f);
};
用法应如下所示:
for (auto& element : MyFilter(input, 4)) {
std::cout << "Element = " << element << std::endl;
}
不幸的是,它再次只打印了 4。这对我来说很奇怪??
现在,我自己得到了解决方案。我必须删除我的 lambda 函数中的"&"才能使其工作!
在:
auto myFilter = [](const std::vector<int>& v, int r) {
return v | boost::adaptors::filtered([&r](auto v) { return v%r == 0; });
};
它返回另一个范围适配器,而r
被引用捕获的则成为悬空引用。要修复它,请按值捕获r
:
auto myFilter = [](const std::vector<int>& v, int r) {
return v | boost::adaptors::filtered([r](auto v) { return v%r == 0; });
}; ^
+--- capture by value
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 如何在c++迭代器类型中包装std::chrono
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 对于set上的循环-获取next元素迭代器
- 为什么output_editor Concept不需要output_e迭代器标记
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器
- 不明白迭代器,引用和指针失效,一个例子
- 我可以使用反向迭代器作为ForwardIt吗
- ESP8266单片机矢量迭代器的C++问题
- 如何在C++中将迭代器作为函数参数传递
- 是否应避免从非常量迭代器转换为常量迭代器?
- 如何使用提升范围将自定义迭代器封装在函数中
- 使用 stl 迭代器封装向量是否很好?如果是?怎么可能呢?
- 封装迭代器提供的对象