美文网首页
Python基础(11)-数字数据类型及其所具备的方法

Python基础(11)-数字数据类型及其所具备的方法

作者: 皓月的简书 | 来源:发表于2017-02-19 21:33 被阅读0次

11.1-创建整型:

第一种方式:

>>> i = 123
>>> type(i)
<class 'int'>

第二种方式:

>>> i = int(123)
>>> type(i)
<class 'int'>

以上两种方式都是创建一个整型对象,一模一样没有任何区别,本质上第一种方式在内部会转换成第二种方式,然后会去调用 int 类的 __init__() 这个构造方法,然后会在内存里开辟一块空间用来存储数据。

def __init__(self, x, base=10): # known special case of int.__init__

通过源码可以看出, __init__() 可以有两个参数,默认情况下参数 base 是不用加的,因为默认有值, base=10 就是默认我们要传入的参数是十进制,参数 x 是对象的值。

如果第一个参数是字符串时,可以自定义参数base。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
i = int("0b101",base=2)     #传入的参数需要是二进制
print(i)

运行结果:

11.2-int内部优化机制:

i1 = 123
i2 = 123

一般来说,创建第一个对象时,会在内存里开辟一块空间,用来存储 123 ,并指向 i1 。

创建第二个对象时,又会在内存里开辟一块空间,用来存储 123 ,并指向 i2 。

那来看一下是否会在内存里开辟两块空间,可以用 id()函数 来查看对象的内存地址:

>>> i1 = 123
>>> i2 = 123
>>> id(i1),id(i2)
(1354890864, 1354890864)

通过上面的结果,可以看出 i1 和 i2 的内存地址是相同的,都是指向的 1354890864 ,就代表他们的值都是使用的同一块空间。

这是因为Python的一个优化机制,如果创建多个123,会在内存里开辟相应数量的空间,是非常浪费内存的,所以当多个对象的值都是同一个时,那么这些对象都会使用同一个内存地址。

但是这里的值是有范围的,这个范围里的数字是经常用到的,如果在这个范围里的数字,重复去创建的话,都会默认指向同一个内存地址,这个范围是 -5~257

>>> i1 = 258
>>> i2 = 258
>>> id(i1),id(i2)
(7093008, 1330672)

通过上面的结果,我们可以看出,如果超出这个范围,就不会指向同一个内存地址。

11.3-整型(int)内部方法介绍:

__add__(self, *args, **kwargs):

说明:相当于 + 号。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
i1 = 123
i2 = 456

#带两个下划线的方法都是有特殊的功能的。
#执行的时候python解释器会把 + 转换成一个可以执行的东西,把 + 变成 __add__ 。
#其实本质上就是调用了一下 n1 提供的方法
print(i1 + i2)

#__add__()就是 n1 提供的方法,就是 + 在内部转换成的东西
print(i1.__add__(i2))

运行结果:

注:只要是带双下划线的,都是Python内部去调用的,有特殊意义,在没有学面向对象之前都是用不到的。

bit_length(self):

说明:获取当前数字可表示二进制的最短位数(表示转换成的二进制,二进制最少可以占几位)。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
i1 = 4

#bit_length()获取可表示二进制的最短位数
ret = i1.bit_length()
print(ret)

运行结果:

相关文章

网友评论

      本文标题:Python基础(11)-数字数据类型及其所具备的方法

      本文链接:https://www.haomeiwen.com/subject/pvnjwttx.html