C++11新特性(11)- 标准库函数begin和end

遍历数组元素的方法


假设有一个数组:


int a1[]{1, 2, 3, 4, 5};


遍历数组的所有元素,可以这样:


for(unsigned int i = 0; i < sizeof(a1)/sizeof(a1[0]); ++i){

       cout << a1[i] << endl;

 }

扫描二维码关注公众号,回复: 188130 查看本文章


也可以这样:


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的对称而存在的。


觉得本文有帮助?请分享给更多人。
阅读更多更新文章,请扫描下面二维码,关注微信公众号【面向对象思考】

猜你喜欢

转载自blog.csdn.net/craftsman1970/article/details/79996086