开始介绍 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