std::size, std::ssize

来自cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
迭代器原语
算法概念与工具
间接可调用概念
常用算法要求
工具
迭代器适配器
流迭代器
迭代器定制点
迭代器操作
(C++11)
(C++11)
范围访问
(C++11)(C++14)
(C++11)(C++14)
sizessize
(C++17)(C++20)
(C++14)(C++14)
(C++14)(C++14)
(C++17)
(C++17)
 
在标头 <array> 定义
在标头 <deque> 定义
在标头 <forward_list> 定义
在标头 <iterator> 定义
在标头 <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());
(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 起)

返回给定范围的大小。

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

参数

c - 拥有 size 成员函数的容器或视图
array - 任意类型的数组

返回值

carray 的大小。

异常

1-2) 可能抛出实现定义的异常。

重载

可以为不暴露适合的 size() 成员函数的类或枚举提供 size 的自定义重载,从而能检测它。

实参依赖查找所找到的 size 重载能用于定制 std::ranges::sizestd::ranges::ssizestd::ranges::empty 的行为。

(C++20 起)

可能的实现

版本一
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';
 
    uint32_t b[4] = { 100, 200, 300 };
    std::cout << std::size(b) << '\n'; // 和 sizeof b 的结果不同
 
    char c[4] = { 'a', 'b', 'c' };
    std::cout << std::size(c) << '\n'; // 和 sizeof c 的结果相同
}

输出:

3
3
4
4

参阅

在两个指针相减时返回的有符号整数类型
(typedef)
sizeof 运算符返回的无符号整数类型
(typedef)
返回等于范围大小的整数
(定制点对象)
返回等于范围大小的有符号整数
(定制点对象)