C++之begin()和end()分析(C艹11)

版权声明:转载请声明出处,谢谢~ https://blog.csdn.net/what951006/article/details/72898609

被一网友问到过个这个问题,看了下源码,差不多应该明白了

例子:

int a[] = {1,3,5,7,9};
std::for_each(std::begin<int>(a), std::end<int>(a), [&](int n) {cout << n;});
//这样会把13579输出来。

1,先看一下begin和end这源码

template<class _Tp>
    constexpr const _Tp*
    begin(initializer_list<_Tp> __ils) noexcept
    { return __ils.begin(); }

  /**
   *  @brief  Return an iterator pointing to one past the last element
   *          of the initializer_list.
   *  @param  __ils  Initializer list.
   */
  template<class _Tp>
    constexpr const _Tp*
    end(initializer_list<_Tp> __ils) noexcept
    { return __ils.end(); }

2.嘿!原来是调用了一个initializer_list这个类模版的begin和end方法,我们可以继续查看

 // The compiler can call a private constructor.这个编译器主动调用的构造函数,开发者调用不了
      constexpr initializer_list(const_iterator __a, size_type __l)
      : _M_array(__a), _M_len(__l) { }

 //size()方法直接返回_M_len,也就是编译器确定的长度
      constexpr size_type
      size() const noexcept { return _M_len; }

  //begin()方法直接返回_M_array,首地址了
      constexpr const_iterator
      begin() const noexcept { return _M_array; }

  //end()方法返回的时首地址加上数组长度,即尾端
      constexpr const_iterator
      end() const noexcept { return begin() + size(); }

这下应该明白了,是编译器的锅。

更多文章:http://blog.csdn.net/what951006?viewmode=list
powered by:小乌龟在大乌龟背上~

阅读更多
换一批

没有更多推荐了,返回首页