std::numeric_limits<T>::is_modulo
來自 cppreference.com
static const bool is_modulo; |
(C++11 前) | |
static constexpr bool is_modulo; |
(C++11 起) | |
對於所有以取模算術處理溢位的算術型別 T
,std::numeric_limits<T>::is_modulo 的值為 true。也就是說,如果該型別的加、減、乘或除法的結果會落在範圍 [
min(),
max()]
之外,則這種運算所返回的值與期望值之差是 max() - min() + 1 的倍數。
對於有符號整數型別,is_modulo
為 false,除非實現定義有符號整數溢位為迴繞。
目錄 |
[編輯] 標準特化
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 在大多數機器上曾被要求對有符號整數型別為 truesigned integer types on most machines |
要求對有符號整數型別為 false 除非有符號整數溢位被定義為迴繞 |
- ↑ 該定義為“兩個正數相加的結果可以迴繞為更小的第三個數”。它有以下問題:
- 未定義迴繞後的值。
- 未說明結果是否可重複。
- 未要求對所有值進行加法、減法和其他運算都有已定義的行為。
[編輯] 參閱
[靜態] |
確定整數型別 (公開靜態成員常量) |
[靜態] |
確定 IEC 559/IEEE 754 浮點型別 (公開靜態成員常量) |
[靜態] |
確定精確型別 (公開靜態成員常量) |