在 C++11 之前,C++ 标准中的整数类型包括short
、int
、long
等,这些类型的大小和范围在不同的平台和编译器实现中可能会有所不同。
随着计算机硬件的发展,特别是 64 位架构的普及,需要能够处理更大整数范围的需求日益增加。为了解决这个问题,C++11 标准引入了long long
和unsigned long long
这两种新的整数类型,它们至少提供了 64 位的整数范围。
long long
和unsigned long long
long long
:至少提供64位的有符号整数存储能力,其取值范围至少是-263到263-1。unsigned long long
:至少提供64位的无符号整数存储能力,其取值范围至少是0到2^64-1。
特点
- 扩展整数范围:
long long
和unsigned long long
提供了比int
和long
更大的整数范围,使得程序能够处理更大的整数值。 - 跨平台一致性:虽然
short
、int
、long
的大小在不同平台上可能不同,但 C++11 保证long long
至少 64 位,增加了代码的可移植性。 - 性能考虑:在 64 位系统上,
long long
操作通常能够得到硬件直接支持,但在 32 位系统上可能需要额外的指令来处理 64 位整数运算。
使用示例
基本使用
#include <iostream>
#include <limits>
int main() {
long long ll_min = std::numeric_limits<long long>::min(); // 最小值
long long ll_max = std::numeric_limits<long long>::max(); // 最大值
std::cout << "The range of long long is from "
<< ll_min << " to " << ll_max << "." << std::endl;
unsigned long long ull_max = std::numeric_limits<unsigned long long>::max(); // 无符号最大值
std::cout << "The maximum value of unsigned long long is "
<< ull_max << "." << std::endl;
return 0;
}
输出:
The range of long long is from -9223372036854775808 to 9223372036854775807.
The maximum value of unsigned long long is 18446744073709551615.
处理大整数
#include <iostream>
int main() {
long long a = 9223372036854775807LL; // 直接使用字面量初始化
long long b = a + 1; // 这将导致溢出
std::cout << "a = " << a << std::endl;
std::cout << "b (a + 1) = " << b << " (overflow)" << std::endl;
unsigned long long c = 18446744073709551615ULL; // 无符号最大值
unsigned long long d = c + 1; // 无符号类型的溢出会回绕
std::cout << "c = " << c << std::endl;
std::cout << "d (c + 1) = " << d << " (wrap around)" << std::endl;
return 0;
}
输出:
a = 9223372036854775807
b (a + 1) = -9223372036854775808 (overflow)
c = 18446744073709551615
d (c + 1) = 0 (wrap around)
注意事项
- 使用
long long
时,字面量后应加上LL
或ll
后缀来确保字面量被解释为long long
类型。 - 对于
unsigned long long
,使用ULL
或ull
后缀。 - 虽然
long long
提供了更大的整数范围,但在某些操作上可能比较小的整数类型慢,特别是在32位系统上。 - 在进行可能导致溢出的操作时,需要特别注意,尤其是在处理有符号类型时,溢出的行为是未定义的(UB - undefined behavior)。
总结
long long
和unsigned long long
是 C++11 中引入的两种整数类型,它们至少提供 64位 的整数存储能力,极大地扩展了 C++ 程序可以处理的整数范围。这使得 C++ 程序能够更容易地处理大整数,同时保持良好的跨平台兼容性。