问题
假设有一个数组:
int a1[]{1, 2, 3, 4, 5};
可以这样:
for(unsigned int i = 0; i < sizeof(a1) / sizeof(a1[0]); i++){
printf("%d\t", a1[i]);
}
或者这样:
for(int *p = a1; p != a1 + sizeof(a1) / sizeof(a1[0]); p++){
printf("%d\t", *p);
}
多少还是需要一点技巧的。
再看下面的代码。
void output(int data[]){
for(unsigned int i = 0; i < sizeof(data)/sizeof(data[0]); i++){
cout << data[i] << endl;
}
}
虽然代码可以通过编译(可能有警告),但是不能正常工作。原因是data实际上是一个指针,因此不能正确计算数组的大小。
解决
上面代码的主要难点在于数组尾地址的计算。为了降低这里的难度,C++11引入了begin和end函数:
for(int* i = begin(a1); i != end(a1); i++){
printf("%d\t", *i);
}
代码简练,目的清晰。
再回到上面的函数:
void output(int data[]){
for(int* p = begin(data); p != end(data); p++){
cout << *p << endl;
}
}
照样清晰,照样简练,但是不能通过编译。这样就避免了错误的发生
注:begin并没有绝对的必要性,恐怕只是作为end的对称而存在的。