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