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


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

    函数模板 

    std::end
    C++11
    容器 (1)    
    template  auto end (Container& cont) -> decltype (cont.end());
    template  auto end (const Container& cont) -> decltype (cont.end());
    数组 (2)    
    template  T* end (T(&arr)[N]);
    C++14
    容器 (1)    
    template  auto end (Container& cont) -> decltype (cont.end());
    template  auto end (const Container& cont) -> decltype (cont.end());
    数组 (2)    
    template  constexpr T* end (T(&arr)[N]) noexcept;
    指向结束的iterator
    返回一个指向序列结束后的元素的iterator:
    (1)容器
    函数返回cont.end()。
    (2)数组
    函数返回arr+N。
    如果序列为,则返回值与以相同实参的begin返回的值比较相等。
    这些函数模板在多个头文件中定义:每个头文件都包含所有容器和数组类型的泛型模板,而不仅仅是特定的重载。头文件是: map, 
    相反,end在头文件中重载(使用不同的定义)。

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

    返回值
    对于(1),与cont.end()返回的值相同。
    对于(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可用于访问或修改它们。

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

  • 相关阅读:
    3.1-分类-概率生成模型
    SpringCloud-Sentinel
    IEC103设备数据 转 IEC61850项目案例
    数学建模经验分享,matlab
    .NET MVC 修改项目URL为IP
    c#如何判断一个类型是否为数值类型,请给出通用方法
    HTML+CSS实现登陆页面样式布局、网页设计练习案例
    jacob解决freemaker导出word文档手机无法预览问题(附下载地址)
    泛型基础使用
    HIVE消费者画像
  • 原文地址:https://blog.csdn.net/weixin_40186813/article/details/127642149