Namespaces
Variants

std:: is_signed

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
is_signed
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
定義先ヘッダ <type_traits>
template < class T >
struct is_signed ;
(C++11以降)

std::is_signed UnaryTypeTrait です。

T が符号付き算術型であるかどうかをチェックします。

  • std:: is_arithmetic < T > :: value true の場合、メンバー定数 value T ( - 1 ) < T ( 0 ) に等しい値として提供します。
  • それ以外の場合、メンバー定数 value false に等しい値として提供します。

プログラムが std::is_signed または std::is_signed_v に対する特殊化を追加する場合、動作は未定義です。

目次

テンプレートパラメータ

T - チェックする型

ヘルパー変数テンプレート

template < class T >
constexpr bool is_signed_v = is_signed < T > :: value ;
(C++17以降)

std::integral_constantから継承

メンバ定数

value
[static]
true T が符号付き算術型の場合は false それ以外の場合は
(public static member constant)

メンバ関数

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

メンバ型

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

実装例

namespace detail
{
    template<typename T, bool = std::is_arithmetic<T>::value>
    struct is_signed : std::integral_constant<bool, T(-1) < T(0)> {};
    template<typename T>
    struct is_signed<T, false> : std::false_type {};
}
template<typename T>
struct is_signed : detail::is_signed<T>::type {};
(注:指定された条件により、HTMLタグ・属性、 タグ内のテキスト、C++専門用語は翻訳対象外となっています。上記コードブロック内のテキストは全て翻訳対象外要素のため、原文のまま保持されています)

#include <iostream>
#include <type_traits>
class A {};
static_assert(std::is_signed_v<A> == false);
class B { int i; };
static_assert(std::is_signed_v<B> == false);
enum C : int {};
static_assert(std::is_signed_v<C> == false);
enum class D : int {};
static_assert(std::is_signed_v<D> == false);
static_assert
(
    std::is_signed<signed int>::value == true and // C++11
    std::is_signed<signed int>() == true and      // C++11
    std::is_signed<signed int>{} == true and      // C++11
    std::is_signed_v<signed int> == true and      // C++17
    std::is_signed_v<unsigned int> == false and
    std::is_signed_v<float> == true and
    std::is_signed_v<bool> == false and
    std::is_signed_v<signed char> == true and
    std::is_signed_v<unsigned char> == false
);
int main()
{
    // charの符号付き/符号なしは実装定義:
    std::cout << std::boolalpha << std::is_signed_v<char> << '\n';
}

出力例:

true

不具合報告

以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。

DR 適用対象 公開時の動作 正しい動作
LWG 2197 C++11 value T が算術型でない場合でも true になる可能性があった この場合 false のみ可能

関連項目

型が符号なし算術型かどうかをチェックする
(クラステンプレート)
[static]
符号付き型を識別する
( std::numeric_limits<T> のpublic staticメンバ定数)
型が算術型かどうかをチェックする
(クラステンプレート)
指定された整数型に対応する符号付き型を取得する
(クラステンプレート)
指定された整数型に対応する符号なし型を取得する
(クラステンプレート)