迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > C++ >

在 C++ 中指定 64 位整数

作者:迹忆客 最近更新:2023/09/03 浏览次数:

在本文中,我们将讨论和学习如何在 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++ 中的大整数

下一篇:没有了

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

C++ 中的大整数

发布时间:2023/09/02 浏览次数:151 分类:C++

在本文中,我们将讨论在 C++ 中处理大整数。 首先,我们将讨论 C++ 中的原始整数类型及其范围,然后讨论如何处理大于原始整数类型限制的整数。C++ 中的整数数据类型

在 C++ 中使用 128 位整数

发布时间:2023/09/02 浏览次数:170 分类:C++

在本文中,我们将讨论 C++ 中的 128 位整数。 我们还将了解为什么需要它以及 C++ 中可能的替代方案。

C++ 井字棋游戏

发布时间:2023/09/02 浏览次数:107 分类:C++

本文将讨论使用 C++ 中的条件语句和循环创建 tic tac toe 游戏。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 浏览次数:161 分类:C++

本文将讨论使用 C++ 中的 delete 关键字为二叉搜索树创建析构函数。C++ 二叉搜索树析构函数

C++ 中负数的模数

发布时间:2023/08/31 浏览次数:121 分类:C++

在本文中,我们将发现余数和模数之间的差异。 我们将了解 % 运算符的基础知识。稍后,我们将了解 % 运算符在 Python 和 C++ 中的行为方式。 最后,我们将通过讨论在 C++ 中实现模数功能的几种

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便