std::mdspan<T,Extents,LayoutPolicy,AccessorPolicy>::mdspan
constexpr explicit mdspan( data_handle_type p, OtherIndexTypes... exts );
constexpr explicit(N != rank_dynamic())
constexpr explicit(N != rank_dynamic())
mdspan( data_handle_type p,
const accessor_type& a );
class OtherLayoutPolicy, class OtherAccessor >
constexpr explicit(/* see below */)
mdspan( const mdspan<OtherElementType, OtherExtents,
Constructs an mdspan
, optionally using user-supplied data handle p, layout mapping m, and accessor a. If extents exts or ext are supplied, they are converted to extents_type
and used to initialize the layout mapping.
Contents
[edit] Parameters
std::extents
object
[edit] Effects
For the data members listed in the table below:
- If the corresponding initializer is empty, the data member is value-initialized.
- If the corresponding intiializer is not empty, the data member is direct-non-list-initialized with that initializer.
Overload | Initializer for... | ||
---|---|---|---|
ptr_
|
map_
|
acc_
| |
(1) | (empty) | ||
(2) | std::move(p) | extents_type (static_cast<index_type> (std::move(exts))...) |
(empty) |
(3) | extents_type(exts) | ||
(4) | |||
(5) | ext | ||
(6) | m | ||
(7) | a | ||
(8) | other.ptr_
|
other.map_
|
other.acc_
|
[edit] Constraints and supplement information
- rank_dynamic() > 0
- std::is_default_constructible_v <data_handle_type>
- std::is_default_constructible_v <mapping_type>
- std::is_default_constructible_v <accessor_type>
[
0,
map_
.required_span_size())
is not an accessible range of ptr_
and acc_
for the values of map_
and acc_
after the invocation of this constructor, the behavior is undefined.- (std::is_convertible_v <OtherIndexTypes, index_type> && ...)
- (std::is_nothrow_constructible <index_type, OtherIndexTypes> && ...)
- sizeof...(OtherIndexTypes) == rank() || sizeof...(OtherIndexTypes) == rank_dynamic()
- std::is_constructible_v <mapping_type, extents_type>
- std::is_default_constructible_v <accessor_type>
[
0,
map_
.required_span_size())
is not an accessible range of p and acc_
for the values of map_
and acc_
after the invocation of these constructors, the behavior is undefined.- std::is_convertible_v <const OtherIndexType&, index_type>
- std::is_nothrow_constructible_v <index_type, const OtherIndexType&>
- N == rank() || N == rank_dynamic()
- std::is_constructible_v <mapping_type, extents_type>
- std::is_default_constructible_v <accessor_type>
[
0,
map_
.required_span_size())
is not an accessible range of p and acc_
for the values of map_
and acc_
after the invocation of these constructors, the behavior is undefined.- std::is_constructible_v <mapping_type, const extents_type&>
- std::is_default_constructible_v <accessor_type>
[
0,
map_
.required_span_size())
is not an accessible range of p and acc_
for the values of map_
and acc_
after the invocation of these constructors, the behavior is undefined.[
0,
m.required_span_size())
is an accessible range of p and acc_
for the value of acc_
after the invocation of this constructor, the behavior is undefined.[
0,
m.required_span_size())
is not an accessible range of p and a, the behavior is undefined.mapping_type>
|| !std::is_convertible_v <const OtherAccessor&, accessor_type>.
- std::is_constructible_v
<mapping_type, const OtherLayoutPolicy::template mapping<OtherExtents>&> - std::is_default_constructible_v <accessor_type>
- std::is_constructible_v <data_handle_type, const OtherAccessor::data_handle_type&>
- std::is_constructible_v <extents_type, OtherExtents>
[
0,
map_
.required_span_size())
is not an accessible range of ptr_
and acc_
for the values of ptr_
, map_
and acc_
after the invocation of this constructor, the behavior is undefined.If static_extent(r) == std::dynamic_extent
|| static_extent(r) == other.extent(r) is false for some rank index r of extents_type
, the behavior is undefined.
If static_extent(r) == std::dynamic_extent
|| static_extent(r) == other.extent(r) is false for some rank index r of extents_type
:
- If the implementation is hardened, a contract violation occurs. Moreover, if the contract-violation handler returns under "observe" evaluation semantic, the behavior is undefined.
- If the implementation is not hardened, the behavior is undefined.
[edit] Example
Reason: no example
[edit] References
- C++23 standard (ISO/IEC 14882:2024):
- 24.7.3.6.2 Constructors [mdspan.mdspan.cons]