python中的int 对象,永不溢出的整数

开始介绍 int 对象前,先考考大家:下面这个 C 程序( test.c )运行后输出什么?是 1000000000000 (一万亿)吗?

#include<stdio.h></stdio.h>

int main(int argc, char *argv[]){

int value = 1000000;

printf("%d\n", value * value);

return 0;

}

可能有不少人觉得这没啥好问的,一百万乘以一百万不就是一万亿吗?但现实却不是如此。

在计算机中,由于变量类型存储空间固定,它能表示的数值范围也是有限的。以 int 为例,该类型长度为 32 位,能表示的整数范围为 -2147483648 至 2147483647 。一万亿显然超出该范围,换句话讲程序发生了 整数溢出 。因此,运行 test.c ,程序这样输出也就不奇怪了:

$ gcc -o test test.c$ ./test

-727379968

不仅是 C 语言,很多编程语言都存在整数溢出的问题,数据库中的整数类型也是。由于整数溢出现象的存在,程序员需要结合业务场景,谨慎选择数据类型。一旦选择不慎或者代码考虑不周,便会导致严重 BUG 。

int 对象的行为

与其他语言相比, Python 中的整数永远不会有溢出的现象。一百万乘以一百万, Python 可以轻易算出来:

>>> 1000000 * 10000001000000000000

Python 甚至可以计算十的一百次方,这在其他语言是不可想象的:

>>> 10 ** 10010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000

计算结果如此庞大,就算用 64 位整数,也难以表示。但 Python 中的整数对象缺可以轻松应付,完全不需要任何特殊处理。为什么 Python 整数有这样的魔力呢?让我们深入整数对象源码,拨开心中的迷雾。

在源码中,我们将领略到 C 语言 实现大整数的艺术 。也许你曾经被面试官要求用 C/C++ 实现大整数,却因为考虑不周而不幸败北。不要紧,掌握 Python 整数的设计秘密后,实现大整数对你来说将是易如反掌。

int 对象的设计

int 对象在 In

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值