std::end(std::valarray) - cppreference.com (original) (raw)

template< class T > /* see below */ end( valarray<T>& v ); (1) (since C++11)
template< class T > /* see below */ end( const valarray<T>& v ); (2) (since C++11)

The overload of std::end for valarray returns an iterator of unspecified type referring to the one past the last element in the numeric array.

  1. The return type must
  1. The return type must

The iterator returned from this function is invalidated when the member function resize() is called on v or when the lifetime of v ends, whichever comes first.

Contents

[edit] Parameters

[edit] Return value

Iterator to one past the last value in the numeric array.

[edit] Exceptions

May throw implementation-defined exceptions.

[edit] Notes

Unlike other functions that take std::valarray arguments, end() cannot accept the replacement types (such as the types produced by expression templates) that may be returned from expressions involving valarrays: std::end(v1 + v2) is not portable, std::end(std::valarray<T>(v1 + v2)) has to be used instead.

The intent of this function is to allow range for loops to work with valarrays, not to provide container semantics.

[edit] Example

#include #include #include   int main() { const std::valarray va { 'H', 'e', 'l', 'l', 'o', ',', ' ', 'C', '+', '+', '!', '\n' };   std::for_each(std::begin(va), std::end(va), [](char c){ std::cout << c; }); }

Output:

[edit] Defect reports

The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

DR Applied to Behavior as published Correct behavior
LWG 2058 C++11 1. end() was required to support replacement types2. it was unspecified when the returned iterators will be invalidated 1. not required2. specified

[edit] See also