std::is_floating_point
提供: cppreference.com
<tbody>
</tbody>
| ヘッダ <type_traits> で定義
|
||
template< class T > struct is_floating_point; |
(C++11以上) | |
T が浮動小数点型かどうか調べます。 T が float、double、long double またはその cv 修飾された型であれば、 true に等しいメンバ定数 value が提供されます。 そうでなければ、 value は false に等しくなります。
is_floating_point または is_floating_point_v (C++17以上) に対して特殊化を追加するプログラムは未定義です。
テンプレート引数
| T | - | 調べる型 |
ヘルパー変数テンプレート
<tbody> </tbody> template< class T > inline constexpr bool is_floating_point_v = is_floating_point<T>::value; |
(C++17以上) | |
std::integral_constant から継承
メンバ定数
value [静的] |
T が浮動小数点型 (またはその cv 修飾された型)ならば true、そうでなければ false (パブリック静的メンバ定数) |
メンバ関数
operator bool |
オブジェクトを bool に変換します。 value を返します (パブリックメンバ関数) |
operator() (C++14) |
value を返します (パブリックメンバ関数) |
メンバ型
| 型 | 定義 |
value_type
|
bool
|
type
|
std::integral_constant<bool, value>
|
実装例
template< class T >
struct is_floating_point
: std::integral_constant<
bool,
std::is_same<float, typename std::remove_cv<T>::type>::value ||
std::is_same<double, typename std::remove_cv<T>::type>::value ||
std::is_same<long double, typename std::remove_cv<T>::type>::value
> {};
|
例
Run this code
#include <iostream>
#include <type_traits>
class A {};
int main()
{
std::cout << std::boolalpha;
std::cout << std::is_floating_point<A>::value << '\n';
std::cout << std::is_floating_point<float>::value << '\n';
std::cout << std::is_floating_point<int>::value << '\n';
}
出力:
false
true
false
関連項目
[静的] |
IEC 559/IEEE 754 の浮動小数点型を識別します ( std::numeric_limits<T>のパブリック静的メンバ定数)
|
(C++11) |
型が整数型かどうか調べます (クラステンプレート) |
(C++11) |
型が算術型かどうか調べます (クラステンプレート) |