Python中整数的最大可能值是多少?
与C/C++不同,Python3中的Long具有无限的精度,并且没有明确定义的限制。可用地址空间的数量被视为实际限制。
在python2中,整数超过限制会自动切换为long-
Python2
>>> import sys >>> type(sys.maxint) <type 'int'> >>> type(sys.maxint + 1) <type 'long'>
Python3
Maxint已在python3中删除,但通常可以使用sys.maxsize代替。
>>> import sys >>> type (sys.maxsize) <class 'int'> >>> type (sys.maxsize + 1) <class 'int'>
从上面的输出中我们可以看到,在python3中,int和long实际上是合并的,并且值没有这种重要性。
#Python2.7
>>> import sys >>> print sys.maxint# Max Integer value 2147483647 >>> print -sys.maxint -1# Min. Ineteger value -2147483648
但是在python3中,我们可以分配一个比这个更高的值,因为这次范围会增加。sys.maxint替换为sys.maxsize。
#在Python3.6中
>>> import sys >>> print(sys.maxsize) 2147483647
最大和最小整数,longs和float值
#Python 2.7 import sys print("Float value information: ",sys.float_info) print("\n") print("Long Integer value information: ",sys.long_info) print("\n") print("Maximum size of an integer: ",sys.maxsize)
输出
('Float value information: ', sys.float_info(max=1.7976931348623157e+308, max_exp=1024, max_10_exp=308, min=2.2250738585072014e-308, min_exp=-1021, min_10_exp=-307, dig=15, mant_dig=53, epsilon=2.220446049250313e-16, radix=2, rounds=1)) ('Long Integer value information: ', sys.long_info(bits_per_digit=30, sizeof_digit=4)) ('Maximum size of an integer: ', 9223372036854775807L)
#Python3.6
import sys print("Float value information: ",sys.float_info) print("\nInteger value information: ",sys.int_info) print("\nMaximum size of an integer: ",sys.maxsize)
输出
Float value information: sys.float_info(max=1.7976931348623157e+308, max_exp=1024, max_10_exp=308, min=2.2250738585072014e-308, min_exp=-1021, min_10_exp=-307, dig=15, mant_dig=53, epsilon=2.220446049250313e-16, radix=2, rounds=1) Integer value information: sys.int_info(bits_per_digit=15, sizeof_digit=2) Maximum size of an integer: 2147483647