Scroll to navigation

std::unsigned_integral(3) C++ Standard Libary std::unsigned_integral(3)

NAME

std::unsigned_integral - std::unsigned_integral

Synopsis


Defined in header <concepts>
template< class T >
concept unsigned_integral = std::integral<T> && (since C++20)
!std::signed_integral<T>;


The concept unsigned_integral<T> is satisfied if and only if T is an integral type
and std::is_signed_v<T> is false.

Notes


unsigned_integral<T> may be satisfied by a type that is not an unsigned integer
type, for example, bool.

Example

// Run this code


#include <concepts>
#include <iostream>
#include <string_view>


void test(std::signed_integral auto x, std::string_view text = "")
{
std::cout << text << " (" + (text == "") << x << ") is a signed integral\n";
}


void test(std::unsigned_integral auto x, std::string_view text = "")
{
std::cout << text << " (" + (text == "") << x << ") is an unsigned integral\n";
}


void test(auto x, std::string_view text = "")
{
std::cout << text << " (" + (text == "") << x << ") is non-integral\n";
}


int main()
{
test(42); // signed
test(0xFULL, "0xFULL"); // unsigned
test('A'); // platform-dependent
test(true, "true"); // unsigned
test(4e-2, "4e-2"); // non-integral (hex-float)
test("∫∫"); // non-integral
}

Possible output:


(42) is a signed integral
0xFULL (15) is an unsigned integral
(A) is a signed integral
true (1) is an unsigned integral
4e-2 (0.04) is non-integral
(∫∫) is non-integral

See also


is_integral checks if a type is an integral type
(C++11) (class template)
is_signed checks if a type is a signed arithmetic type
(C++11) (class template)

2024.06.10 http://cppreference.com