名稱空間
變體
操作

std::numeric_limits<T>::is_modulo

來自 cppreference.com
< cpp‎ | 型別‎ | 數值限制
 
 
 
 
 
static const bool is_modulo;
(C++11 前)
static constexpr bool is_modulo;
(C++11 起)

對於所有以取模算術處理溢位的算術型別 Tstd::numeric_limits<T>::is_modulo 的值為 true。也就是說,如果該型別的加、減、乘或除法的結果會落在範圍 [min()max()] 之外,則這種運算所返回的值與期望值之差是 max() - min() + 1 的倍數。

對於有符號整數型別,is_modulofalse,除非實現定義有符號整數溢位為迴繞。

目錄

[編輯] 標準特化

T std::numeric_limits<T>::is_modulo 的值
/* 未特化 */ false
bool false
char 實現定義
signed char 實現定義
unsigned char true
wchar_t 實現定義
char8_t (C++20起) true
char16_t (C++11起) true
char32_t (C++11起) true
short 實現定義
unsigned short true
int 實現定義
unsigned int true
long 實現定義
unsigned long true
long long (C++11) 實現定義
unsigned long long (C++11) true
float false
double false
long double false

[編輯] 注意

在解決 LWG 問題 2422 之前,標準曾說“在大多數機器上,這對有符號整數是 true”。相關討論見 GCC PR 22200

[編輯] 示例

演示取模型別的行為

#include <iostream>
#include <type_traits>
#include <limits>
 
template<class T>
typename std::enable_if<std::numeric_limits<T>::is_modulo>::type
    check_overflow()
{
    std::cout << "max value is " << std::numeric_limits<T>::max() << '\n'
              << "min value is " << std::numeric_limits<T>::min() << '\n'
              << "max value + 1 is " << std::numeric_limits<T>::max()+1 << '\n';
}
 
int main()
{
    check_overflow<int>();
    std::cout << '\n';
    check_overflow<unsigned long>();
//  check_overflow<float>(); // compile-time error, not a modulo type
}

可能的輸出

max value is 2147483647
min value is -2147483648
max value + 1 is -2147483648
 
max value is 18446744073709551615
min value is 0
max value + 1 is 0

[編輯] 缺陷報告

下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
LWG 612 C++98 “以取模算術處理溢位”的定義不佳[1]
with modulo arithmetic" was poor[1]
提供了一個更好的定義
better definition
LWG 2422 C++98 is_modulo 在大多數機器上曾被要求對有符號整數型別為 true
signed integer types on most machines
要求對有符號整數型別為 false
除非有符號整數溢位被定義為迴繞
  1. 該定義為“兩個正數相加的結果可以迴繞為更小的第三個數”。它有以下問題:
    • 未定義迴繞後的值。
    • 未說明結果是否可重複。
    • 未要求對所有值進行加法、減法和其他運算都有已定義的行為。

[編輯] 參閱

[靜態]
確定整數型別
(公開靜態成員常量) [編輯]
[靜態]
確定 IEC 559/IEEE 754 浮點型別
(公開靜態成員常量) [編輯]
[靜態]
確定精確型別
(公開靜態成員常量) [編輯]