鍍金池/ 問(wèn)答/C++  網(wǎng)絡(luò)安全/ C++ 標(biāo)準(zhǔn)庫(kù)容器為什么增加了 cbegin 和 cend 方法?

C++ 標(biāo)準(zhǔn)庫(kù)容器為什么增加了 cbegin 和 cend 方法?

C++11 之前的標(biāo)準(zhǔn)庫(kù)容器對(duì) begin 和 end 重載了常量對(duì)象和非常量對(duì)象版本,而在 11 中又對(duì)常量版本行定義了 cbegin 和 cend。

11 這樣做的意義何在,也即這樣的設(shè)計(jì),相比 11 之前有什么優(yōu)勢(shì)?

回答
編輯回答
怣痛

cbegin和cend等是在c++14開(kāi)始添加的, 並非c++11

TL;DR, 是爲(wèi)了更方便的獲得常量迭代器.
在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)

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

再者, 其實(shí)現(xiàn)也非常簡(jiǎn)單, 利用現(xiàn)有設(shè)施很容易, 不會(huì)破壞core laungage:

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

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

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

更新:

窩跟你說(shuō)...這裏有人在c++14出臺(tái)之前抱怨?fàn)?wèi)什麼沒(méi)有const 版本的std::begin()抱怨, 然後草藥大叔親自登場(chǎng)了...

2017年11月24日 23:43