千家信息网

C++11的cbegin和cend函数怎么使用

发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,本篇内容介绍了"C++11的cbegin和cend函数怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学
千家信息网最后更新 2025年02月04日C++11的cbegin和cend函数怎么使用

本篇内容介绍了"C++11的cbegin和cend函数怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

const迭代器

先看下面的程序:

sum = 0;

vector v{1, 2, 3, 4, 5, 6};

vector::iterator it = v.begin();

while(it != v.end()){

sum += *it;

it++;

}


代码先是取得了vector的迭代器,然后遍历vector求和。再看下面的代码:

sum = 0;

const vector cv{1, 2, 3, 4, 5, 6};

vector::iterator cit = cv.begin();

while(cit != v.end()){

sum += *cit;

cit++;

}

这段代码是不能通过编译的,原因是定义的vector是const类型,所以迭代器必须也是const类型。代码需要做如下修改:

sum = 0;

const vector cv{1, 2, 3, 4, 5, 6};

vector::const_iterator cit = cv.begin();

while(cit != v.end()){

sum += *cit;

cit++;

}

另一个办法是使用auto类型修饰符:

sum = 0;

auto ait = cv.begin();

while(ait != cv.end()){

sum += *ait;

ait++;

}

省去了人工区分迭代器类型的麻烦,又不会妨碍const类型迭代器的功能。

更进一步

vector本身是const类型,生成的迭代器就必须是const类型。这样,在编译层次就避免了可能发生的对vector数据的修改。

还有另外一种情况,数据本身不是const类型,但是从设计的角度来讲有些处理不应该修改该数据。这时也应该要求const类型的迭代器,以避免数据被意外修改。

C++11为此提供了cbegin和cend方法。

vector v{1, 2, 3, 4, 5, 6};、

auto ait = v.cbegin();

while(ait != v.cend()){

sum += *ait;

*ait = sum; //编译错误

ait++;

}

cbegin()/cend()决定了返回的迭代器类型为const。这时即使vector的类型不是const,也可以防止对该数据的误操作。

"C++11的cbegin和cend函数怎么使用"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

0