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 |