std::size, std::ssize

来自cppreference.com
< cpp‎ | iterator
定义于头文件 <iterator>
template <class C>
constexpr auto size(const C& c) -> decltype(c.size());
(1) (C++17 起)
template <class C>

constexpr auto ssize(const C& c)
    -> std::common_type_t<std::ptrdiff_t,

                          std::make_signed_t<decltype(c.size())>>;
(2) (C++20 起)
template <class T, std::size_t N>
constexpr std::size_t size(const T (&array)[N]) noexcept;
(3) (C++17 起)
template <class T, std::ptrdiff_t N>
constexpr std::ptrdiff_t ssize(const T (&array)[N]) noexcept;
(4) (C++20 起)

返回给定容器 c 或数组 array 的大小。

1-2) 返回 c.size() ,若需要则转换到返回类型。
3-4) 返回 N

目录

[编辑] 参数

c - 拥有 size 方法的容器
array - 任意类型的数组

[编辑] 返回值

carray 的大小。

[编辑] 注意

除了包含于 <iterator> ,若包含下列任一头文件,则保证 std::sizestd::ssize 可用: <array><deque><forward_list><list><map><regex><set> <span> (C++20 起)<string><string_view><unordered_map><unordered_set><vector>

[编辑] 可能的实现

版本一
template <class C> 
constexpr auto size(const C& c) -> decltype(c.size())
{
    return c.size();
}
版本二
template <class C>
constexpr auto ssize(const C& c) 
    -> std::common_type_t<std::ptrdiff_t,
                          std::make_signed_t<decltype(c.size())>> {
    using R = std::common_type_t<std::ptrdiff_t,
                                 std::make_signed_t<decltype(c.size())>>;
    return static_cast<R>(c.size());
}
版本三
template <class T, std::size_t N>
constexpr std::size_t size(const T (&array)[N]) noexcept
{
    return N;
}
版本四
template <class T, std::ptrdiff_t N>
constexpr std::ptrdiff_t ssize(const T (&array)[N]) noexcept
{
    return N;
}

[编辑] 示例

#include <iostream>
#include <vector>
#include <iterator>
 
int main() 
{
    std::vector<int> v = { 3, 1, 4 };
    std::cout << std::size(v) << '\n'; 
 
    int a[] = { -5, 10, 15 };
    std::cout << std::size(a) << '\n';
}

输出:

3
3