迭代器复制构造函数错误,作为右侧'.'运算符非法
Iterator copy constructor error, illegal as right side '.' operator
在检查了这个答案后,我似乎仍然无法解决我的问题:
我目前有一个test_iterator
结构,它将把不同类型的迭代器标记封装在上面,使我能够使用所有类型的迭代器测试函数。我的问题出现在为这个迭代器创建复制构造函数时。当前结构定义为
template <typename BaseIterator, typename IteratorTag>
struct test_iterator
: boost::iterator_adaptor<
test_iterator<BaseIterator, IteratorTag>,
BaseIterator, boost::use_default, IteratorTag>
{
private:
typedef boost::iterator_adaptor<
test_iterator<BaseIterator, IteratorTag>,
BaseIterator, boost::use_default, IteratorTag>
base_type;
public:
test_iterator() : base_type() {}
test_iterator(BaseIterator base) : base_type(base) {};
test_iterator(const test_iterator& cpy):
base_type(cpy.base_type) {};
};
最后一个构造函数(复制构造函数(给我带来了麻烦,我似乎无法理解我做错了什么。我收到的确切错误是
error C2274: 'function-style cast' : illegal as right side of '.' operator
这是哪条线路:
base_type(cpy.base_type) {};
不能在.
的右侧有类型。你可以使用
test_iterator(const test_iterator& cpy)
: base_type(static_cast<base_type const&>(cpy)) {}
或者,假设已经指定了基本类型,您可以只使用
test_iterator(const test_iterator& cpy)
: base_type(cpy) {}
在行
base_type(cpy.base_type) {};
您引用了base_type
,它是一个typedef,并且您想要底层迭代器。您需要调用迭代器_adaptor提供的base()
方法:
base_type(cpy.base()) {};
test_iterator(const test_iterator& cpy):
base_type(cpy.base_type) {};
类test_iterator
没有成员base_type
,但有一个typedef base_type
,所以如果您真的想凭空初始化基础,它将是
test_iterator(const test_iterator& cpy):
base_type(base_type()) {};
但这是毫无意义的,因为这将产生一个nullptr
等价物。
我想你反而想实现
test_iterator(const test_iterator& cpy):
base_type(/*(const base_type&)*/cpy) {};
这是合法的,因为test_iterator
继承自base_type
(我假设基本类型实际上具有采用base_type const&但是下转换是编译器为您所做的,所以您不需要手动进行下转换。
顺便说一句,我认为这个
test_iterator(BaseIterator base) : base_type(base) {};
应该是
test_iterator(const BaseIterator& base) : base_type(base) {};
不应该。
相关文章:
- 为什么比较运算符如此快速
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 增量运算符与后缀混淆
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- 一个关于在C++中重载布尔运算符的问题
- 运算符C++ "delete []"仅删除 2 个前值
- 模板类无法识别友元运算符
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 关闭||运算符优化
- 通过继承类使用来自不同命名空间的运算符
- C++Cast运算符过载
- 如何使用AngelScript注册SFML Vector2运算符
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 布尔比较运算符是如何在C++中工作的
- 迭代器复制构造函数错误,作为右侧'.'运算符非法