返回一个 const 和非 const 包装器对象

return a const and non const wrapper object

本文关键字:const 和非 包装 对象 一个 返回      更新时间:2023-10-16

如果我希望一个自定义容器类通过一个类似迭代器的对象(实际上充当容器中某些数据的包装器)来访问其数据,并且我希望能够同时获得一个常量和非常量迭代器类对象,一个只允许读取,一个允许读写,所以我必须实现两个不同的类似迭代器的对象; 一个只允许读取,一个允许读写, 或者我可以将此功能包装在一个对象中。

问题是我必须按值返回此对象,但我无法返回一个无法直接放入非常量变量中的按值对象,例如

const accessor container::getConstAccessor(){/**/}

被滥用,如

accessor a=myContainer.getConstAccessor(); //effectively giving me a non const

我能看到的唯一解决方案是有两个访问器类/结构。一个作用于常量,一个作用于readWrite,无论它们在常量变量中还是非常量变量中。

这也许模拟了一个 constIterator 和 iterator,但这真的需要吗?您不能创建一个访问器并从容器返回 const 或非 const 版本吗?

我尝试改写这个问题几次,以使其最笼统,但如果它有意义,我并不完全确定。我希望是这样。

您不能创建一个访问器并从容器中返回 const 或 non const 版本吗?

没有。首先,您需要两个访问器,因为您必须检测*this是否const合格:

/* ??? */ my_container::getAccessor();
/* ??? */ my_container::getAccessor() const;

然后,如果按值返回,则无法强制getAccessor的调用方将返回值存储在const变量中。这就是为什么如果要在const限定的访问器中强制实施不可变性,则需要两种不同的类型:

accessor my_container::getAccessor();
const_accessor my_container::getAccessor() const;

通过实现accessorconst_accessor,很可能可以通过一些可以用T/const T实例化的模板accessor_impl<T>类来避免代码重复。