std::pair<T1,T2>:: pair
|
pair
(
)
;
|
(1) |
(C++11以降 constexpr)
(C++11以降 条件付き explicit) |
|
pair
(
const
T1
&
x,
const
T2
&
y
)
;
|
(2) |
(C++11以降 条件付き explicit)
(C++14以降 constexpr) |
| (3) | ||
|
template
<
class
U1,
class
U2
>
pair ( U1 && x, U2 && y ) ; |
(C++11以降)
(C++23まで) (C++14以降constexpr) (条件付きexplicit) |
|
|
template
<
class
U1
=
T1,
class
U2
=
T2
>
constexpr pair ( U1 && x, U2 && y ) ; |
(C++23以降)
(条件付きexplicit) |
|
|
template
<
class
U1,
class
U2
>
constexpr pair ( pair < U1, U2 > & p ) ; |
(4) |
(C++23以降)
(条件付きexplicit) |
|
template
<
class
U1,
class
U2
>
pair ( const pair < U1, U2 > & p ) ; |
(5) |
(C++11以降 条件付きexplicit)
(C++14以降 constexpr) |
|
template
<
class
U1,
class
U2
>
pair ( pair < U1, U2 > && p ) ; |
(6) |
(C++14以降 constexpr)
(C++11以降 条件付きexplicit) |
|
template
<
class
U1,
class
U2
>
constexpr pair ( const pair < U1, U2 > && p ) ; |
(7) |
(C++23以降)
(条件付きexplicit) |
|
template
<
pair
-
like P
>
constexpr pair ( P && u ) ; |
(8) |
(C++23以降)
(条件付きexplicit) |
|
template
<
class
...
Args1
,
class
...
Args2
>
pair
(
std::
piecewise_construct_t
,
|
(9) |
(C++11以降)
(C++20以降 constexpr) |
|
pair
(
const
pair
&
p
)
=
default
;
|
(10) | |
|
pair
(
pair
&&
p
)
=
default
;
|
(11) | (C++11以降) |
新しいペアを構築します。
first
と
second
を値初期化する。
|
このコンストラクタは、 std:: is_default_constructible_v < T1 > および std:: is_default_constructible_v < T2 > がともに true である場合にのみ、オーバーロード解決に参加する。
このコンストラクタは、
|
(C++11以降) |
first
を
x
で、
second
を
y
で初期化する。
|
このコンストラクタは、 std:: is_copy_constructible_v < T1 > と std:: is_copy_constructible_v < T2 > が両方とも true である場合に限り、オーバーロード解決に参加する。 このコンストラクタは、 std:: is_convertible_v < const T1 & , T1 > が false であるか、または std:: is_convertible_v < const T2 & , T2 > が false である場合に限り、 explicit となる。 |
(C++11以降) |
|
このコンストラクタは、
|
(C++23以降) |
first
を
p.
first
で、
second
を
p.
second
で初期化します。
first
または
second
の初期化が一時オブジェクトへの参照をバインドする場合、このコンストラクタは削除定義されます。
first
を
p.
first
で、
second
を
p.
second
で初期化する。
|
このコンストラクタは、 std:: is_constructible_v < T1, const U1 & > と std:: is_constructible_v < T2, const U2 & > が両方とも true の場合にのみオーバーロード解決に参加する。 このコンストラクタは、 std:: is_convertible_v < const U1 & , T1 > が false であるか、または std:: is_convertible_v < const U2 & , T2 > が false である場合にのみ explicit となる。 |
(C++11以降) |
|
|
(C++23以降) |
first
を
std::
forward
<
U1
>
(
p.
first
)
で初期化し、
second
を
std::
forward
<
U2
>
(
p.
second
)
で初期化する。
|
このコンストラクタは、
|
(C++23以降) |
first
を
std::
forward
<
const
U1
>
(
p.
first
)
で初期化し、
second
を
std::
forward
<
const
U2
>
(
p.
second
)
で初期化します。
first
または
second
の初期化が一時オブジェクトへの参照をバインドする場合、このコンストラクタは削除定義されます。
U1
および
U2
と表記する。
first
を
u1
で、
second
を
u2
で初期化する。
- std:: remove_cvref ( P ) が std::ranges::subrange の特殊化ではない場合、
- std:: is_constructible_v < T1, U1 > が true である場合、および
- std:: is_constructible_v < T2, U2 が true である場合。
first
または
second
の初期化が一時オブジェクトへの参照をバインドする場合、削除定義されます。
first
のコンストラクタに転送し、
second_args
の要素を
second
のコンストラクタに転送する。これは、コピー不可・ムーブ不可の型のペアを作成するために使用できる唯一の非デフォルトコンストラクタである。
first
または
second
が参照であり、一時オブジェクトにバインドされている場合、プログラムは不適格となる。
目次 |
パラメータ
| x | - | このペアの最初の要素を初期化する値 |
| y | - | このペアの2番目の要素を初期化する値 |
| p | - | このペアの両方の要素を初期化するために使用される値のペア |
| u | - | pair-like このペアの両方の要素を初期化するために使用される値のペアライクオブジェクト |
| first_args | - | このペアの最初の要素を初期化するためのコンストラクタ引数のタプル |
| second_args | - | このペアの2番目の要素を初期化するためのコンストラクタ引数のタプル |
例外
指定された操作(例:要素のコンストラクタ)が例外をスローしない限り、例外をスローしません。
例
#include <complex> #include <iostream> #include <string> #include <tuple> #include <utility> int main() { auto print = [](auto rem, auto const& pair) { std::cout << rem << "(" << pair.first << ", " << pair.second << ")\n"; }; std::pair<int, float> p1; print("(1) Value-initialized: ", p1); std::pair<int, double> p2{42, 3.1415}; print("(2) Initialized with two values: ", p2); std::pair<char, int> p4{p2}; print("(4) Implicitly converted: ", p4); std::pair<std::complex<double>, std::string> p6 {std::piecewise_construct, std::forward_as_tuple(0.123, 7.7), std::forward_as_tuple(10, 'a')}; print("(8) Piecewise constructed: ", p6); }
出力例:
(1) Value-initialized: (0, 0) (2) Initialized with two values: (42, 3.1415) (4) Implicitly converted: (*, 3) (8) Piecewise constructed: ((0.123,7.7), aaaaaaaaaa)
欠陥報告
以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。
| DR | 適用対象 | 公開時の動作 | 正しい動作 |
|---|---|---|---|
| LWG 265 | C++98 |
デフォルトコンストラクタが
first
と
second
を
T1
(
)
と
T2
(
)
でそれぞれコピー初期化していた
(したがって
T1
と
T2
が
CopyConstructible
であることを要求していた)
|
first
と
second
は値初期化される |
| LWG 2510 | C++11 | デフォルトコンストラクタが暗黙的であった | 条件付き明示的になった |
| N4387 | C++11 | 一部のコンストラクタが暗黙的のみで、一部の使用を妨げていた | コンストラクタが条件付き明示的になった |
関連項目
引数の型によって決定される型の
pair
オブジェクトを作成する
(関数テンプレート) |
|
新しい
tuple
を構築する
(
std::tuple<Types...>
の公開メンバ関数)
|