std::size, std::ssize
提供: cppreference.com
| ヘッダ <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) |
(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 | - | 任意の型の配列 |
[編集] 戻り値
c または array のサイズ。
[編集] ノート
<iterator> がインクルードされた場合に加えて <array>、 <deque>、 <forward_list>、 <list>、 <map>、 <regex>、 <set>、 <span> (C++20以上)、 <string>、 <string_view>、 <unordered_map>、 <unordered_set>、 <vector> のいずれかのヘッダがインクルードされた場合も、 std::size および std::ssize が利用可能になることが保証されています。
[編集] 実装例
| 1つめのバージョン |
|---|
template <class C> constexpr auto size(const C& c) -> decltype(c.size()) { return c.size(); } |
| 2つめのバージョン |
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()); } |
| 3つめのバージョン |
template <class T, std::size_t N> constexpr std::size_t size(const T (&array)[N]) noexcept { return N; } |
| 4つめのバージョン |
template <class T, std::ptrdiff_t N> constexpr std::ptrdiff_t ssize(const T (&array)[N]) noexcept { return N; } |
[編集] 例
Run this code
#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

