• C++ Reference: Standard C++ Library reference: Others: iterator: begin


    C++官网参考链接:https://cplusplus.com/reference/iterator/begin/

    函数模板 
    <deque>
    std::begin
    C++11
    容器 (1)    
    template  auto begin (Container& cont) -> decltype (cont.begin());
    template  auto begin (const Container& cont) -> decltype (cont.begin());
    数组 (2)    
    template  T* begin (T(&arr)[N]);
    C++14
    容器 (1)    
    template  auto begin (Container& cont) -> decltype (cont.begin());
    template  auto begin (const Container& cont) -> decltype (cont.begin());
    数组 (2)    
    template  constexpr T* begin (T(&arr)[N]) noexcept;
    指向开始的iterator
    返回一个指向序列中第一个元素的iterator:
    (1)容器
    函数返回cont.begin()。
    (2)数组
    函数返回其实参的数组到指针的转换。
    如果序列为空,则返回值不应该被解引用。 
    这些函数模板在多个头文件中定义:每个头文件都包含所有容器和数组类型的通用模板,而不仅仅是特定的重载。头文件是:map
    相反,begin在头文件中重载(使用不同的定义)。

    形参 
    cont 
    定义了成员begin的类类型的对象。
    arr
    一个数组。

    返回值
    对于(1),与cont.begin()返回的值相同。
    对于(2),指向数组中第一个元素的指针。

    用例
    // std::begin / std::end example
    #include     // std::cout
    #include       // std::vector, std::begin, std::end

    int main () {
      int foo[] = {10,20,30,40,50};
      std::vector bar;

      // iterate foo: inserting into bar
      for (auto it = std::begin(foo); it!=std::end(foo); ++it)
        bar.push_back(*it);

      // iterate bar: print contents:
      std::cout << "bar contains:";
      for (auto it = std::begin(bar); it!=std::end(bar); ++it)
        std::cout << ' ' << *it;
      std::cout << '\n';

      return 0;
    }
    输出:

    数据竞争
    访问但不修改实参。
    序列中的所有元素都不能被调用访问,但是返回的iterator可用于访问或修改它们。

    异常安全
    提供与对实参执行的操作相同级别的保证(对于标准容器和数组,这是无抛出保证)。

  • 相关阅读:
    排序算法大总结
    JVM 学习笔记
    51 爬楼梯
    dubbo通信原理
    Docker02:名词解释与安装
    taro超过3行隐藏显示展开功能
    基于SSM的青少年编程学习系统设计与实现
    英特尔近30年来首次季度亏损,市值被AMD反超
    Mysql基础
    LINUX笔记温习
  • 原文地址:https://blog.csdn.net/weixin_40186813/article/details/127641720