在 C++ 中指定 64 位整数
在本文中,我们将讨论和学习如何在 C++ 中指定 64 位整数。 此外,当使用 64 位整数出现问题时,我们将比较旧方法。
在 C++ 中指定 64 位整数
我们有多种选择来处理 C++ 中的整数。 从 int 数据类型开始到 long int 和 64 位的 long long int,您可以使用以下代码检查大小:
#include <iostream>
using namespace std;
int main(){
long long int v;
cout << sizeof(v) << '\n';
return 0;
}
输出为 8 字节或 64 位。 我们使用以下代码来比较一下 long long int
可以处理的最大值:
#include <iostream>
using namespace std;
int main(){
long long int v = 9223372036854775807;
cout << sizeof(v) << '\n';
cout << v << '\n';
return 0;
}
输出为 9223372036854775807,即8个字节。 然而,我们会得到一个错误,说,如果增加 v 的值,整数常量太大,它是无符号的。
这意味着 9223372036854775807 是正确处理的正值的最大范围。 如果将此数字转换为十六进制,则该值为 7FFFFFFFFFFFFFFF。
这意味着除了符号位之外,所有位都是 1。 同样,负整数的最大范围是 -9223372036854775808。
因此,64位整数似乎没有问题; 然而,在过去,许多处理器无法处理 64 位整数。 因此,相同的代码给出了错误的输出。
例如,当我们尝试存储以下信息时出现错误消息。 查看代码和相关错误消息:
long long int h2 = 0x4444000044444;
错误消息是:
warning: overflow in implicit constant conversion
warning: integer constant is too large for its type
除了 long long int
之外,stdint.h 中还有另一种类型可用,即 int64_t。 同样,如果您检查大小,您将得到 8 字节或 64 位。 然而,结果是一样的。
讨论得出的结论是,我们过去在 C++ 中使用 64 位整数时遇到了问题。 它依赖于编译器和架构; 然而,这个问题现在在较新的编译器版本中不存在。
人们可以安全地处理 long long int 或 int64_t 中的 64 位整数。 这些类型不仅可以存储值,还可以执行数学运算,只要结果在 64 位以内即可。
相关文章
Arduino 复位
发布时间:2024/03/13 浏览次数:315 分类:C++
-
可以通过使用复位按钮,Softwarereset 库和 Adafruit SleepyDog 库来复位 Arduino。
Arduino 的字符转换为整型
发布时间:2024/03/13 浏览次数:181 分类:C++
-
可以使用简单的方法 toInt()函数和 Serial.parseInt()函数将 char 转换为 int。
Arduino 串口打印多个变量
发布时间:2024/03/13 浏览次数:381 分类:C++
-
可以使用 Serial.print()和 Serial.println()函数在串口监视器上显示变量值。