名前空間
変種
操作

std::is_invocable, std::is_invocable_r, std::is_nothrow_invocable, std::is_nothrow_invocable_r

From cppreference.com
< cpp‎ | types
 
 
メタプログラミングライブラリ
型特性
型のカテゴリ
(C++11)
(C++11)(DR*)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11) 
(C++11)
(C++11)
型のプロパティ
(C++11)
(C++11)
(C++14)
(C++11)(C++26で非推奨)
(C++11)(C++20まで*)
(C++11)(C++20で非推奨)
(C++11)
型特性定数
メタ関数
(C++17)
サポートされている操作
関係とプロパティクエリ
(C++11)
(C++11)
(C++11)
is_invocableis_invocable_ris_nothrow_invocableis_nothrow_invocable_r
(C++17)(C++17)(C++17)(C++17)
型の変更
(C++11)(C++11)(C++11)
型の変換
(C++11)(C++23で非推奨)
(C++11)(C++23で非推奨)
(C++11)
(C++11)(C++20まで*)(C++17)

(C++11)
(C++17)
コンパイル時有理数演算
コンパイル時整数シーケンス
 
ヘッダ <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) INVOKE(std::declval<Fn>(), std::declval<ArgTypes>()...) が未評価オペランドとして扱われた場合に整形式であるかどうかを判定します。
2) INVOKE<R>(std::declval<Fn>(), std::declval<ArgTypes>()...) が未評価オペランドとして扱われた場合に整形式であるかどうかを判定します。
3) INVOKE(std::declval<Fn>(), std::declval<ArgTypes>()...) が未評価オペランドとして扱われた場合に整形式であり、かつ例外をスローしないことが分かっているかどうかを判定します。
4) INVOKE<R>(std::declval<Fn>(), std::declval<ArgTypes>()...) が未評価オペランドとして扱われた場合に整形式であり、かつ例外をスローしないことが分かっているかどうかを判定します。

FnR、またはパラメータパック ArgTypes 内の型がいずれも完全な型、(cv修飾された) void、または境界不明の配列ではない場合、動作は未定義です。

上記のテンプレートのインスタンス化が、直接的または間接的に不完全な型に依存し、その型が仮に完全になった場合にそのインスタンス化が異なる結果を生み出す可能性がある場合、動作は未定義です。

プログラムがこのページで説明されているテンプレートのいずれかに特殊化を追加する場合、動作は未定義です。

目次

[編集] ヘルパー変数テンプレート

ヘッダ <type_traits> で定義
template< class Fn, class... ArgTypes >

inline constexpr bool is_invocable_v =

    std::is_invocable<Fn, ArgTypes...>::value;
(1) (C++17以降)
template< class R, class Fn, class... ArgTypes >

inline constexpr bool is_invocable_r_v =

    std::is_invocable_r<R, Fn, ArgTypes...>::value;
(2) (C++17以降)
template< class Fn, class... ArgTypes >

inline constexpr bool is_nothrow_invocable_v =

    std::is_nothrow_invocable<Fn, ArgTypes...>::value;
(3) (C++17以降)
template< class R, class Fn, class... ArgTypes >

inline constexpr bool is_nothrow_invocable_r_v =

    std::is_nothrow_invocable_r<R, Fn, ArgTypes...>::value;
(4) (C++17以降)

std::integral_constant から継承

メンバ定数

value
[static]
(オーバーロード (1) の場合) INVOKE(std::declval<Fn>(), std::declval<ArgTypes>()...) が未評価オペランドとして扱われた場合に整形式であれば true、そうでなければ false
(公開静的メンバ定数)

メンバ関数

operator bool
オブジェクトを bool に変換し、value を返します。
(public member function)
operator()
(C++14)
value を返します。
(public member function)

メンバ型

定義
value_type bool
type std::integral_constant<bool, value>

[編集] 備考

機能テストマクロ 規格 機能
__cpp_lib_is_invocable 201703L (C++17) std::is_invocable, std::invoke_result

[編集] 使用例

#include <type_traits>
 
auto func2(char) -> int (*)()
{
    return nullptr;
}
 
int main()
{
    static_assert(std::is_invocable_v<int()>);
    static_assert(not std::is_invocable_v<int(), int>);
    static_assert(std::is_invocable_r_v<int, int()>);
    static_assert(not std::is_invocable_r_v<int*, int()>);
    static_assert(std::is_invocable_r_v<void, void(int), int>);
    static_assert(not std::is_invocable_r_v<void, void(int), void>);
    static_assert(std::is_invocable_r_v<int(*)(), decltype(func2), char>);
    static_assert(not std::is_invocable_r_v<int(*)(), decltype(func2), void>);
}

[編集] 関連項目

(C++17)(C++23)
任意の呼び出し可能 (Callable)オブジェクトを所与の引数で呼び出す (戻り値の型を指定することも可能)(C++23以降)
(関数テンプレート) [編集]
(C++11)(C++20で削除)(C++17)
呼び出し可能オブジェクトを引数のセットで呼び出した結果の型を推論する
(クラステンプレート) [編集]
(C++11)
評価されない文脈で使用するために、テンプレート型引数のオブジェクトへの参照を取得する
(関数テンプレート) [編集]
呼び出し可能型が、与えられた一連の引数型で呼び出し可能であることを規定する
(コンセプト) [編集]
English 日本語 中文(简体) 中文(繁體)