存储在std::map中的c++基迭代器
C++ base iterator stored within std::map
我想在一个简单的代码示例中展示一些想法:
class Base{
public:
void doSomeNastyThings(int param)
{
IteratorInterface *iter_face = iterators[param];
for(auto it = iter_face->begin(); it != iter_face->end(); it++)
{
//do another nasty things
}
}
protected:
std::map<int, IteratorInterface*> iterators;
};
我希望从派生类....填充迭代器映射但是我如何用STL风格创建这样一个IteratorInterface呢?所有的迭代器都将提供对相同类型的访问(让我称之为'T'),但它们可以具有不同的类型:
std::map<T>::iterator, std::vector<T>::iterator, foo<T>::iterator.
一种方法是创建从IteratorInterface派生的模板类,它将对迭代器做一些讨厌的事情,实现IteratorInterface并为您可能希望使用它的每个迭代器提供实现。但首先你应该阅读这篇文章,并重新考虑整个想法。
这是可能的,但不推荐。
您必须创建一个抽象基类模板,例如BaseIteratorImpl<T>
,并为每个不同的迭代器类型创建一个具体的派生类,例如VectorIteratorImpl<T> : public BaseIteratorImpl<T>
。您还需要创建IteratorInterface<T>
来保存和封装指向BaseIteratorImpl<T>
的指针,为迭代器提供熟悉的值语义。
更一般地,而不是VectorIteratorImpl<T>
和ListIteratorImpl<T>
和…可以创建
class IteratorImpl<ContainerType> :
public BaseIteratorImpl<typename ContainerType::value_type>
,如IteratorImpl<vector<double> >
.
IteratorInterface<T>
将把所有常用的迭代器操作转发给它的BaseIteratorImpl<T>
成员。对于这些操作,BaseIteratorImpl<T>
都有一个纯虚函数。IteratorImpl<C>
将实现这些操作。
不建议这样做,因为您将不得不编写大量的代码,并且只会导致巨大的性能损失。
比起迭代器,您应该使用算法来执行此操作(模板化+虚拟化)(在doSomeNastyThings
中发生的事情)
相关文章:
- 使用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++中将迭代器作为函数参数传递
- 是否应避免从非常量迭代器转换为常量迭代器?
- 如何在 c++ 中将字符串迭代器变量传递给函数?
- 为什么 vector 的随机访问迭代器给出与指针不同的内存地址?
- 为什么 C++ std::unordered_map 从 emplace/ 找到返回一个迭代器?