Namespaces
Variants

std:: is_unsigned

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)
(C++11)
is_unsigned
(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
Défini dans l'en-tête <type_traits>
template < class T >
struct is_unsigned ;
(depuis C++11)

std::is_unsigned est un UnaryTypeTrait .

Vérifie si T est un type arithmétique non signé.

  • Si std:: is_arithmetic < T > :: value est true , fournit la constante membre value égale à T ( 0 ) < T ( - 1 ) .
  • Sinon, fournit la constante membre value égale à false .

Si le programme ajoute des spécialisations pour std::is_unsigned ou std::is_unsigned_v , le comportement est indéfini.

Table des matières

Paramètres du modèle

T - un type à vérifier

Modèle de variable d'assistance

template < class T >
constexpr bool is_unsigned_v = is_unsigned < T > :: value ;
(depuis C++17)

Hérité de std:: integral_constant

Constantes membres

value
[static]
true si T est un type intégral non signé, false sinon
(constante membre publique statique)

Fonctions membres

operator bool
convertit l'objet en bool , retourne value
(fonction membre publique)
operator()
(C++14)
retourne value
(fonction membre publique)

Types membres

Type Définition
value_type bool
type std:: integral_constant < bool , value >

Implémentation possible

namespace detail
{
    template<typename T,bool = std::is_arithmetic<T>::value>
    struct is_unsigned : std::integral_constant<bool, T(0) < T(-1)> {};
    template<typename T>
    struct is_unsigned<T,false> : std::false_type {};
} // namespace detail
template<typename T>
struct is_unsigned : detail::is_unsigned<T>::type {};

Exemple

#include <iostream>
#include <type_traits>
class A {};
static_assert(std::is_unsigned_v<A> == false);
enum B : unsigned {};
static_assert(std::is_unsigned_v<B> == false);
enum class C : unsigned {};
static_assert(std::is_unsigned_v<C> == false);
struct S { unsigned p : 1; int q : 1; };
static_assert
(
    std::is_unsigned_v<decltype(S::p)> not_eq
    std::is_unsigned_v<decltype(S::q)>
);
static_assert
(
    std::is_unsigned_v<float> == false &&
    std::is_unsigned_v<signed int> == false &&
    std::is_unsigned_v<unsigned int> == true &&
    std::is_unsigned_v<bool> == true
);
int main() 
{
    // signedness of char is implementation-defined:
    std::cout << std::boolalpha << std::is_unsigned<char>::value << '\n';
}

Sortie possible :

false

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR S'applique à Comportement publié Comportement corrigé
LWG 2197 C++11 value pouvait être true même si T n'est pas un type arithmétique ne peut être que false dans ce cas

Voir aussi

(C++11)
vérifie si un type est un type arithmétique signé
(modèle de classe)
[static]
identifie les types signés
(constante membre statique publique de std::numeric_limits<T> )
vérifie si un type est un type arithmétique
(modèle de classe)
obtient le type signé correspondant pour le type intégral donné
(modèle de classe)
obtient le type non signé correspondant pour le type intégral donné
(modèle de classe)