遍历数组元素的方法
假设有一个数组:
int a1[]{1, 2, 3, 4, 5};
遍历数组的所有元素,可以这样:
for(unsigned int i = 0; i < sizeof(a1)/sizeof(a1[0]); ++i){
cout << a1[i] << endl;
}
也可以这样:
for(int* p1 = a1; p1 != (a1 + sizeof(a1)/sizeof(a1[0]));++p1){
cout << *p1 << endl;
}
多少还是需要一点技巧的。
再看下面的代码。
void output(int data[]){
for(unsigned int i = 0; i < sizeof(data)/sizeof(data[0]); i++){
cout << data[i] << endl;
}
}
虽然代码可以通过编译(可能有警告),但是不能正常工作。原因是data实际上是一个指针,因此不能正确计算数组的大小。
标准库函数begin和end
上面代码的主要难点在于数组尾地址的计算。为了降低这里的难度,C++11引入了begin和end函数。使用begin和end的代码如下:
for(int* p1 = begin(a1); p1 != end(a1); ++p1){
cout << *p1 << endl;
}
代码简练,目的清晰。
再回到上面的函数:
void output(int data[]){
for(int* p = begin(data); p != end(data); p++){
cout << *p << endl;
}
}
照样清晰,照样简练,但是不能通过编译。这样就避免了错误的发生。
作者观点
begin并没有绝对的必要性,恐怕只是作为end的对称而存在的。
觉得本文有帮助?请分享给更多人。
关注【面向对象思考】,轻松学习每一天!
面向对象设计,面向对象编程,面向对象思考!
网友评论