C/C++培训
达内IT学院
400-996-5531
const迭代器
先看下面的程序:
sum = 0;
vector<int> v{1, 2, 3, 4, 5, 6};
vector<int>::iterator it = v.begin();
while(it != v.end()){
sum += *it;
it++;
}
代码先是取得了vector的迭代器,然后遍历vector求和。再看下面的代码:
sum = 0;
const vector<int> cv{1, 2, 3, 4, 5, 6};
vector<int>::iterator cit = cv.begin();
while(cit != v.end()){
sum += *cit;
cit++;
}
这段代码是不能通过编译的,原因是定义的vector是const类型,所以迭代器必须也是const类型。代码需要做如下修改:
sum = 0;
const vector<int> cv{1, 2, 3, 4, 5, 6};
vector<int>::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<int> 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,也可以防止对该数据的误操作。
作者观点
为了安全,不该给的不给,不该拿的不拿。做人如此,编程亦然。
本文内容转载自网络,本着分享与传播的原则,版权归原作者所有,如有侵权请联系我们进行删除!
填写下面表单即可预约申请免费试听!怕钱不够?可就业挣钱后再付学费! 怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!
Copyright © 京ICP备08000853号-56 京公网安备 11010802029508号 达内时代科技集团有限公司 版权所有
Tedu.cn All Rights Reserved