迭代器复制构造函数错误,作为右侧'.'运算符非法

Iterator copy constructor error, illegal as right side '.' operator

本文关键字:非法 运算符 构造函数 复制 错误 迭代器      更新时间:2023-10-16

在检查了这个答案后,我似乎仍然无法解决我的问题:

我目前有一个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) {};

不应该。