std::is_literal_type
提供: cppreference.com
ヘッダ <type_traits> で定義 | ||
template<class T > struct is_literal_type; | (C++11以上) (C++17で非推奨) (C++20で削除) | |
T
が LiteralType の要件をすべて満たす場合、 true に等しいメンバ定数 value
が提供されます。 それ以外の型に対しては、 value
は false です。
std::remove_all_extents_t<T> が不完全型であり、 void (または cv 修飾された void) でない場合、動作は未定義です。
is_literal_type
または is_literal_type_v
(C++17以上) に対して特殊化を追加するプログラムは未定義です。
目次 |
[編集]テンプレート引数
T | - | 調べる型 |
[編集] ヘルパー変数テンプレート
template<class T > inlineconstexprbool is_literal_type_v = is_literal_type<T>::value; | (C++17以上) (非推奨) (C++20で削除) | |
std::integral_constant から継承
メンバ定数
value [静的] | T がリテラル型ならば true、そうでなければ false(パブリック静的メンバ定数) |
メンバ関数
operator bool | オブジェクトを bool に変換します。 value を返します (パブリックメンバ関数) |
operator() (C++14) | value を返します (パブリックメンバ関数) |
メンバ型
型 | 定義 |
value_type | bool |
type | std::integral_constant<bool, value> |
[編集]ノート
constexpr 関数に引数として使用したり戻り値として返したりできるのはリテラル型だけです。 constexpr メンバ関数を持てるのはリテラルクラスだけです。
[編集]例
Run this code
#include <iostream>#include <type_traits> struct A {int m;}; struct B {virtual ~B();}; int main(){std::cout<<std::boolalpha;std::cout<< std::is_literal_type<A>::value<<'\n';std::cout<< std::is_literal_type<B>::value<<'\n';}
出力:
true false