C++ 标准库容器为什么增加了 cbegin 和 cend 方法?

C++11 之前的标准库容器对 begin 和 end 重载了常量对象和非常量对象版本,而在 11 中又对常量版本行定义了 cbegin 和 cend。

11 这样做的意义何在,也即这样的设计,相比 11 之前有什么优势?

阅读 3.4k
1 个回答

cbegin和cend等是在c++14開始添加的, 並非c++11

TL;DR, 是爲了更方便的獲得常量迭代器.
在c++14以前, 你像要得到常量迭代器, 方法比較繁瑣:

typedef vector<MyType> vect;
typedef vect::const_iterator c_iter;
vect v;
// alternatives:
c_iter it = const_cast<vect const &>(v).begin(); // 1
c_iter it = static_cast<c_iter>( v.begin() ); // 2 (explicit)
c_iter it = v.begin(); // 2 (implicit)

雖然現在const有被濫用的趨勢, 但是該用的時候還是要用, 比如fold, 或者其在c++中的等價函數, std::accumulate, 不需要懟迭代器指向的成員進行修改, 此時const-qualify有其合理性.

再者, 其實現也非常簡單, 利用現有設施很容易, 不會破壞core laungage:

const_iterator cbegin() const;
const_iterator cend () const;

最後, 它與c++0x的其它特性, 比如auto/decltype可以相互配合, 威力成倍增強, 比如如果沒有cbegin, auto只能得到non-const版本.

其實這種問題最好的解決方法就是去 wg21 看其在2004年的提案, http://www.open-std.org/jtc1/...

更新:

窩跟你說...這裏有人在c++14出臺之前抱怨爲什麼沒有const 版本的std::begin()抱怨, 然後草藥大叔親自登場了...

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题