c++中的迭代器类别
iterator categories in c++
本网站上有关于迭代器类别的说明:
迭代器的每个类别不是由特定类型定义的,而是由可在其上执行的操作定义的。这个定义意味着任何支持必要操作的类型都可以用作迭代器
是否可以在运行前强制执行(类似于必须实现的java接口)?
任何东西都可以将自己声明为特定类别的迭代器,而无需实现所需的所有方法。
它是如何执行的?非常简单。如果您尝试将此类别与使用特定类别操作符的方法或函数一起使用,则会得到编译错误,因为这些操作符没有定义。编译器强制它。
但是迭代器类别的实际使用恰恰是向后的。模板假定标识自己为特定类别的迭代器完全实现了需求,并使用该迭代器的类别来验证它是哪种类型的迭代器,否则强制编译错误。
例如(就在我的脑海中),假设你希望你的模板函数只用于随机访问迭代器:
template<typename iterator_category> class must_be_random_access_iterator;
template<> class must_be_random_access_iterator<std::random_access_iterator_tag> {
public:
typedef int or_else;
};
template<typename iter_type> void some_func(iter_type iter)
{
typedef must_be_random_access_iterator<
typename std::iterator_traits<iter_type>::iterator_category
>::or_else or_else;
// ... more code
}
must_be_random_access_iterator
模板专用于std::random_access_iterator_tag
类别,否则它是未定义的,因此将其他迭代器类型传递给模板函数将导致编译错误。
相关文章:
- 使用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/ 找到返回一个迭代器?