主要的目的

  • 为了让指针更加简单、安全,引入了begin和end函数,这两个函数和容器中两个同名的成员函数类似。但是由于数组毕竟不是类类型,因此这两个函数不是成员函数。
  • 正确的使用形式就是将数组作为他们的参数
    int ia[] = {0,1,2,3,4,5,6,7,8,9};
    int *beg = begin(ia);
    int *last = end(ia);
  • begin函数返回指向数组的首元素的指针,end函数返回指向数组尾元素的下一个位置的指针,这两个函数都被定义在iterator的头文件中。使用begin和end函数就可以很好地处理数组中的元素
  • 例子:从数组中找到第一个负数
int main(){
    int ia[] = {0,1,2,3,-4,5,6,7,8,9,-6};
    int *beg = begin(ia);
    int *last = end(ia);
    //寻找第一个负值的元素,如果已经检查完毕全部元素就结束循环
    while (beg != last){
        if(*beg >= 0){
            *beg++;
        }else{
            cout << *beg;
            break;
        }
    }
    return 0;
}
  • 一个指针如果指向了某种内置类型数组的尾元素的“下一个位置”,则其具备与vector的end函数返回的与迭代器类似的功能。特别要主要的是,尾后指针不能执行解引用和递增操作。
Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐