std::ranges:: empty
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
|
定義先ヘッダ
<ranges>
|
||
|
定義先ヘッダ
<iterator>
|
||
|
inline
namespace
/*unspecified*/
{
inline
constexpr
auto
empty
=
/*unspecified*/
;
|
(C++20以降)
(カスタマイゼーションポイントオブジェクト) |
|
|
呼び出しシグネチャ
|
||
|
template
<
class
T
>
requires
/* see below */
|
(C++20以降) | |
t に要素が存在するかどうかを判定します。
ranges::empty
への呼び出しは、
expression-equivalent
です:
- bool ( t. empty ( ) ) 、その式が有効な場合。
- それ以外の場合、 ( ranges:: size ( t ) == 0 ) 、その式が有効な場合。
- それ以外の場合、 bool ( ranges:: begin ( t ) == ranges:: end ( t ) ) 、その式が有効であり、かつ decltype ( ranges:: begin ( t ) ) が std::forward_iterator をモデル化する場合。
その他のすべての場合において、
ranges::empty
の呼び出しは不適格となり、
置換失敗
を引き起こす可能性があります。これは
ranges
::
empty
(
t
)
がテンプレートのインスタンス化の直接の文脈内に現れる場合に発生します。
カスタマイゼーションポイントオブジェクト
名前
ranges::empty
は
カスタマイゼーションポイントオブジェクト
を表し、これは
関数オブジェクト
のconstな
リテラル
semiregular
クラス型である。詳細は
CustomizationPointObject
を参照。
例
#include <iostream> #include <ranges> #include <vector> template<std::ranges::input_range R> void print(char id, R&& r) { if (std::ranges::empty(r)) { std::cout << '\t' << id << ") Empty\n"; return; } std::cout << '\t' << id << ") Elements:"; for (const auto& element : r) std::cout << ' ' << element; std::cout << '\n'; } int main() { { auto v = std::vector<int>{1, 2, 3}; std::cout << "(1) ranges::empty uses std::vector::empty:\n"; print('a', v); v.clear(); print('b', v); } { std::cout << "(2) ranges::empty uses ranges::size(initializer_list):\n"; auto il = {7, 8, 9}; print('a', il); print('b', std::initializer_list<int>{}); } { std::cout << "(2) ranges::empty on a raw array uses ranges::size:\n"; int array[] = {4, 5, 6}; // array has a known bound print('a', array); } { struct Scanty : private std::vector<int> { using std::vector<int>::begin; using std::vector<int>::end; using std::vector<int>::push_back; // Note: both empty() and size() are hidden }; std::cout << "(3) calling ranges::empty on an object w/o empty() or size():\n"; Scanty y; print('a', y); y.push_back(42); print('b', y); } }
出力:
(1) ranges::empty uses std::vector::empty:
a) Elements: 1 2 3
b) Empty
(2) ranges::empty uses ranges::size(initializer_list):
a) Elements: 7 8 9
b) Empty
(2) ranges::empty on a raw array uses ranges::size:
a) Elements: 4 5 6
(3) calling ranges::empty on an object w/o empty() or size():
a) Empty
b) Elements: 42
関連項目
|
(C++17)
|
コンテナが空かどうかをチェックする
(関数テンプレート) |