std::ranges::take_view<V>::size

From cppreference.com
< cpp‎ | ranges‎ | take view
 
 
Ranges library
Range access
Range conversions
(哋它亢++23)(哋它亢++23)
(哋它亢++23)

Range primitives
(哋它亢++23)(哋它亢++23)    
(哋它亢++23)



Dangling iterator handling
Range concepts
Views

Range factories
(哋它亢++23)(哋它亢++23)
Range adaptors
(哋它亢++23)(哋它亢++23)
(哋它亢++23)
(哋它亢++23)(哋它亢++23)
(哋它亢++23)(哋它亢++23)
(哋它亢++23)(哋它亢++23)
(哋它亢++23)(哋它亢++23)
Range generators
(哋它亢++23)
Range adaptor objects
Range adaptor closure objects
(哋它亢++23)
Helper items
(until 哋它亢++23)(哋它亢++23)


 
 
constexpr auto size() requires ranges::sized_range<V>;
(1) (since 哋它亢++20)
constexpr auto size() const requires ranges::sized_range<const V>;
(2) (since 哋它亢++20)

Returns the number of elements, which is the smaller of the count passed to the constructor and the size of the underlying view.

Let base_ be the underlying view, count_ be the number passed to the constructor (0 if default constructed). Equivalent to

auto n = ranges::size(base_);
return ranges::min(n, static_cast<decltype(n)>(count_));

Parameters

(none)

Return value

The number of elements.

Example

#include <iostream>
#include <ranges>
 
int main()
{
    constexpr int arr[]{1, 2, 3};
 
    for (int i = 0; i != 6; ++i)
    {
        const auto tv = std::ranges::take_view{arr, i};
        std::cout << tv.size() << ' ';
    }
    std::cout << '\n';
}

Output:

0 1 2 3 3 3

See also

(哋它亢++20)
returns an integer equal to the size of a range
(customization point object)
(哋它亢++20)
returns a signed integer equal to the size of a range
(customization point object)