std::is_invocable, std::is_invocable_r, std::is_nothrow_invocable, std::is_nothrow_invocable_r
提供: cppreference.com
ヘッダ <type_traits> で定義 | ||
template<class Fn, class... ArgTypes> struct is_invocable; | (1) | (C++17以上) |
template<class R, class Fn, class... ArgTypes> struct is_invocable_r; | (2) | (C++17以上) |
template<class Fn, class... ArgTypes> struct is_nothrow_invocable; | (3) | (C++17以上) |
template<class R, class Fn, class... ArgTypes> struct is_nothrow_invocable_r; | (4) | (C++17以上) |
1)
Fn
が引数 ArgTypes...
で呼び出すことができるかどうか調べます。 形式的には、未評価の被演算子として扱われたときに INVOKE(declval<Fn>(), declval<ArgTypes>()...)
が well-formed であるかどうかを調べます。 ただし INVOKE
は Callable で定義されている操作です。2)
Fn
が R
に変換可能な結果を生成するために引数 ArgTypes...
で呼び出すことができるかどうか調べます。 形式的には、未評価の被演算子として扱われたときに INVOKE<R>(declval<Fn>(), declval<ArgTypes>()...)
が well-formed であるかどうかを調べます。 ただし INVOKE
は Callable で定義されている操作です。3)
Fn
が引数 ArgTypes...
で呼び出すことができるかどうか ((1) と同じ)、そしてそのような呼び出しがいかなる例外も投げないと判っているかどうか調べます。4)
Fn
が R
に変換可能な結果を生成するために引数 ArgTypes...
で呼び出すことができるかどうか ((2) と同じ)、そしてそのような呼び出し (変換を含む) がいかなる例外も投げないと判っているかどうか調べます。Fn, R
およびパラメータパック ArgTypes
内のすべての型 はいずれも完全型 (またはその cv 修飾された型)、 void、またはサイズの未知な配列でなければなりません。 そうでなければ、動作は未定義です。
上記のテンプレートの実体化が直接または間接的に不完全型に依存しており、もしその型が仮に完全型であったならばその実体化が異なる結果を産むであろう場合は、動作は未定義です。
目次 |
[編集] ヘルパー変数テンプレート
ヘッダ <type_traits> で定義 | ||
template<class Fn, class... ArgTypes> inlineconstexprbool is_invocable_v = std::is_invocable<Fn, ArgTypes...>::value; | (1) | (C++17以上) |
template<class R, class Fn, class... ArgTypes> inlineconstexprbool is_invocable_r_v = std::is_invocable_r<R, Fn, ArgTypes...>::value; | (2) | (C++17以上) |
template<class Fn, class... ArgTypes> inlineconstexprbool is_nothrow_invocable_v = std::is_nothrow_invocable<Fn, ArgTypes...>::value; | (3) | (C++17以上) |
template<class R, class Fn, class... ArgTypes> inlineconstexprbool is_nothrow_invocable_r_v = std::is_nothrow_invocable_r<R, Fn, ArgTypes...>::value; | (4) | (C++17以上) |
std::integral_constant から継承
メンバ定数
value [静的] | 未評価の被演算子として扱われたときに INVOKE<R>(declval<Fn>(), declval<ArgTypes>()...) が well-defined ならば true、そうでなければ false(パブリック静的メンバ定数) |
メンバ関数
operator bool | オブジェクトを bool に変換します。 value を返します (パブリックメンバ関数) |
operator() (C++14) | value を返します (パブリックメンバ関数) |
メンバ型
型 | 定義 |
value_type | bool |
type | std::integral_constant<bool, value> |
[編集]例
Run this code
#include <type_traits> auto func2(char)->int(*)(){return nullptr;} int main(){ static_assert( std::is_invocable<int()>::value); static_assert( std::is_invocable_r<int, int()>::value); static_assert( std::is_invocable_r<void, void(int), int>::value); static_assert( std::is_invocable_r<int(*)(), decltype(func2), char>::value);}
[編集]関連項目
(C++17) | 任意の Callable なオブジェクトを指定された引数で呼びます (関数テンプレート) |
(C++11)(C++20で削除)(C++17) | 指定された引数のセットを渡して callable なオブジェクトを呼んだときの結果の型を推定します (クラステンプレート) |
(C++11) | 未評価文脈で使用するための引数への参照を取得します (関数テンプレート) |