在 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 位以内即可。
相关文章
在 C++ 中使用 128 位整数
发布时间:2023/09/02 浏览次数:170 分类:C++
-
在本文中,我们将讨论 C++ 中的 128 位整数。 我们还将了解为什么需要它以及 C++ 中可能的替代方案。
C++ 中的默认构造函数和 default 关键字
发布时间:2023/09/02 浏览次数:127 分类:C++
-
本文讨论 C++ 中的默认构造函数以及新引入的关键字 default。首先,让我们了解一下C++中的默认构造函数。 默认构造函数是一种特殊的构造函数,它没有参数,用于为类的数据成员设置默认值。
C++ 中的空构造函数
发布时间:2023/09/02 浏览次数:165 分类:C++
-
C++ 中的空构造函数是一种不执行任何操作的特殊类型构造函数。 编译器知道没有代码可以执行,因此不会为构造函数生成任何可执行代码。
C++ 中的结构体构造函数
发布时间:2023/09/02 浏览次数:74 分类:C++
-
这篇文章将讨论 struct 的使用以及使用 C++ 添加构造函数。C++结构体简介 struct 代表结构,是组合了一些基本类型变量的用户定义数据类型。 这些变量混合起来形成一个新的单元。
单链表的 C++ 复制构造函数
发布时间:2023/08/31 浏览次数:59 分类:C++
-
本文将首先讨论链表数据结构的概念以及使用它的合适场景。 然后,我们将讨论使用 C++ 的单链表和单链表的复制构造函数的紧凑实现。
C++ 中负数的模数
发布时间:2023/08/31 浏览次数:121 分类:C++
-
在本文中,我们将发现余数和模数之间的差异。 我们将了解 % 运算符的基础知识。稍后,我们将了解 % 运算符在 Python 和 C++ 中的行为方式。 最后,我们将通过讨论在 C++ 中实现模数功能的几种