- ranges[meta header]
- std::ranges[meta namespace]
- cpo[meta id-type]
- cpp20[meta cpp]
namespace std::ranges {
inline namespace /*unspecified*/ {
inline constexpr /*unspecified*/ data = /*unspecified*/;
}
}
Rangeの要素が格納されたメモリ領域へのポインタを取得する関数オブジェクト。
部分式E
の型をT
、t
をE
を評価した値とする。このとき、式ranges::data(E)
の効果は以下の通り。
E
がrvalueかつenable_borrowed_range
<
remove_cv_t
<T>>
がfalse
であれば、呼び出しは不適格。T
が配列型かつremove_all_extents_t
<T>
が不完全型であれば、呼び出しは不適格(診断不要)。decay-copy
(t.data())
が有効な式でその型がオブジェクトへのポインタであれば、decay-copy
(t.data())
と等しい。ranges::begin
(t)
が有効な式で、その型がcontiguous_iterator
のモデルであれば、to_address
(
ranges::begin
(E))
と等しい。
どれにも当てはまらないとき、呼び出しは不適格。
Rangeの要素が格納されたメモリ領域へのポインタ。
3か4の条件を満たすようにする。例えば、ユーザー定義のクラスにメンバ関数data
を持たせるか、ranges::begin
を通じてカスタマイズできる。
ranges::data(E)
が有効な式であるとき、その型はオブジェクトへのポインタである。
#include <vector>
#include <iostream>
#include <ranges>
void some_c_like_api_function(const int* arr, std::size_t arr_size)
{
std::cout << "array size:" << arr_size << " at " << static_cast<const void*>(arr) << std::endl;
}
int main()
{
int arr[4] = {};
some_c_like_api_function(std::ranges::data(arr), std::ranges::size(arr));
std::vector<int> v { 12 };
some_c_like_api_function(std::ranges::data(v), std::ranges::size(v));
}
- std::ranges::data[color ff0000]
- std::ranges::size[link size.md]
array size:4 at 0x7fff28ab1c50
array size:1 at 0x5596494f02b0
- C++20
- Clang: 13.0.0 [mark verified]
- GCC: 10.1.0 [mark verified]
- ICC: ?
- Visual C++: 2019 Update 10 [mark verified]