std:: make_any
From cppreference.net
C++
Utilities library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
ヘッダーで定義
<any>
|
||
|
template
<
class
T,
class
...
Args
>
std:: any make_any ( Args && ... args ) ; |
(1) | (C++17以降) |
|
template
<
class
T,
class
U,
class
...
Args
>
std:: any make_any ( std:: initializer_list < U > il, Args && ... args ) ; |
(2) | (C++17以降) |
any
オブジェクトを構築し、型
T
のオブジェクトを格納します。提供された引数を
T
のコンストラクタに渡します。
1)
次と等価
return
std::
any
(
std::
in_place_type
<
T
>
,
std::
forward
<
Args
>
(
args
)
...
)
;
2)
次と同等:
return
std::
any
(
std::
in_place_type
<
T
>
, il,
std::
forward
<
Args
>
(
args
)
...
)
;
例
このコードを実行
#include <any> #include <complex> #include <functional> #include <iostream> #include <string> int main() { auto a0 = std::make_any<std::string>("Hello, std::any!\n"); auto a1 = std::make_any<std::complex<double>>(0.1, 2.3); std::cout << std::any_cast<std::string&>(a0); std::cout << std::any_cast<std::complex<double>&>(a1) << '\n'; using lambda = std::function<void(void)>; // std::anyにラムダ式を格納。試行 #1 (失敗) std::any a2 = [] { std::cout << "Lambda #1.\n"; }; std::cout << "a2.type() = \"" << a2.type().name() << "\"\n"; // any_castは<void(void)>にキャストするが、実際の型は // std::function...ではなく、~ main::{lambda()#1}であり、 // 各ラムダ式ごとに一意である。そのため、これは例外をスローする... try { std::any_cast<lambda>(a2)(); } catch (std::bad_any_cast const& ex) { std::cout << ex.what() << '\n'; } // std::anyにラムダ式を格納。試行 #2 (成功) auto a3 = std::make_any<lambda>([] { std::cout << "Lambda #2.\n"; }); std::cout << "a3.type() = \"" << a3.type().name() << "\"\n"; std::any_cast<lambda>(a3)(); }
出力例:
Hello, std::any! (0.1,2.3) a2.type() = "Z4mainEUlvE_" bad any_cast a3.type() = "St8functionIFvvEE" Lambda #2.
関連項目
any
オブジェクトを構築する
(公開メンバ関数) |
|
|
(C++17)
|
包含されたオブジェクトへの型安全なアクセス
(関数テンプレート) |