- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
代码有两个简化的向下迭代器 Cit
和 It
。
It
公开继承自 Cit
以允许从 It
转换为 Cit
,如 foo2。
我认为 It
会从 Cit
继承 int operator-(const self_type& other) const
。但事实并非如此。为什么?
如果我使用 using operator-;
,是否会使 It
继承 Cit< 的两个
?那是错误的。operator-
方法
测试:
#include <vector>
template<typename C>
class Cit {
typedef Cit<C> self_type;
public:
Cit(const C& container, const int ix)
: container_(&container), ix_(ix) {}
self_type operator-(const int n) const {
return self_type(*container_, ix_ - n);
}
int operator-(const self_type& other) const {
return ix_ - other.ix_;
}
const int& operator*() const { return (*container_)[ix_]; }
protected:
const C* container_;
int ix_;
};
template<typename C>
class It : public Cit<C> {
typedef Cit<C> Base;
typedef It<C> self_type;
public:
It(C& container, const int ix)
: Base::Cit(container, ix) {}
self_type operator-(const int n) const {
return self_type(*mutable_a(), ix_ - n);
}
int& operator*() const { return (*mutable_a())[ix_]; }
private:
C* mutable_a() const { return const_cast<C*>(container_); }
using Base::container_;
using Base::ix_;
};
template <typename C>
void foo(Cit<C>& it) {}
int main() {
typedef std::vector<int> V;
V a = {0, 1, 2, 3, 4, 5};
It<V> b(a, 2);
It<V> c(a, 2);
foo(b); // convert from It to Cit works.
b - c; // <----- This doesn't work. Why?
// Assert that result of (b - 1) is an It instead of a Cit.
*(b - 1) -= 1;
}
最佳答案
你的 It<>::operator-(const int n)
隐藏所有 operator-
来自基类 Cit<>
.
您需要添加 using Cit<C>::operator-;
至 It<>
使这些运算符像这样可见:
template<typename C>
class It : public Cit<C> {
//...
public:
//....
using Cit<C>::operator-;
self_type operator-(const int n) const {
return self_type(*mutable_a(), ix_ - n);
}
关于c++ - 迭代器方法无法从 Const_iterator 继承,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50181674/
#include #include using namespace std; void print(vector::const_iterator &beg, vector::const_itera
为什么在 STL 中 std::iterator_traits::value_type 与类型相同 std::iterator_traits::value_type 为什么要这样设计?第一个不应该是c
我正在阅读有关此功能工作方式的不同解释。 cplusplus.com说这个函数应该“直接在 i 之后移动元素”。 然而cppreference.com表示它拼接元素 AT i。 MSvisual st
我正在寻找一种将 std::set::const_iterator 用作我自己的类的 const_iterator 的方法。 我的代码(实际上行为正确并且编译良好)如下: class MyClass{
当我编译以下 MWE 时出现上述错误在 GCC 上 #include void frobnigate( const std::string& str ) { std::string::con
一般背景: 我正在尝试构建一个容器,该容器将作为运行时定义维度的多维数组的包装器 - 事实上,底层数组当然是总大小的一维数组。主要部分是 operator [] 返回子数组上的包装器。 由于容器需要迭
我在尝试使用 const_iterators 时收到运行时错误。错误是:列表迭代器不可取消引用。我知道不能取消引用 const_iterator 以将值分配到列表中,但我试图取消引用迭代器以访问列表中
我有一个方法可以找到 map 中的特定位置并通过迭代器引用“返回”它: bool Func(const int searchKey, MyMap::iterator& iter) const {
我正在用自定义容器扩展STL容器,以便对元素的操作提供更灵活的控制 class MyContainer; template class myiterator :public iterator {
这段代码 std::ostream& operator indent(output.rdbuf()); output.rdbuf(&indent); for (Arra
有件事我实在想不明白。以下情况: 测试.h文件: class Test{ public: const std::list& getItems() { return m_item
我正在从这本名为 Accelerated C++ 的书中学习 C++。一章有这个函数“split”,它接受从“getline”读取的字符串并返回一个充满分离词的 vector 。 vector spl
好的,这是我的问题。有人告诉我,我的类(class)没有匹配的构造函数。这是调用它的代码。 (忽略输入。我输入的内容似乎无关紧要,结果都很糟糕)。 const_iterator end() const
我正在用 C++ 做一个大学项目,其目的是学习如何使用不同的 STL 容器及其迭代器。 在我的程序中,我有一个带有集合的类: class ConjuntoDeLetras{ private:
我正在尝试用 C++ 实现我自己的双向链表 (my_list) 代码,尤其是我的列表的迭代器类。我的问题是我想要从迭代器到 const_iterator 的隐式转换,例如代码 my_list::ite
我的程序结构类似于: class A { private: std::set members; public: void func(const C& a
我有这个声明: list::const_iterator iter; 我正在尝试了解 *iter 的类型是:string* 、const string* 还是其他类型。 我读到 cost_iterat
我正在尝试为我的基于数组的列表类构建一个自定义的 const_iterator 嵌套类。这是类(class) class const_iterator { private: const T *p
我正在大学学习 OOP 类(class)(C++ 是基础语言)。我的任务是实现自己的链表模板容器类。我几乎完全做到了,但遇到了问题。已知STL提供iterator和 const_iterator通过列
我试图理解 const_iterator 的含义。我有以下示例代码: void CustomerService::RefreshCustomers() { for(std::vector::c
我是一名优秀的程序员,十分优秀!