写在开头
会有一个疑问,为什么会把判断类型和判断值的内建函数放到一起?–因为这是笔者参加算法工程师面试的时候被问到的python问题,所以这里放到一起介绍一下。(虽然这些都是很小的点,但是如果面试被问到,很可能放大你的缺点。)
type与isinstance
- type参数只有一个,返回值为变量或者对象的类型,如int, str。
isinstance参数有两个
- 第一个为变量或者对象,第二个参数为是否属于该类型,可以是类名,或者内建类int,str等,也可以是这些类型组成的tuple;
- 返回值为bool类型。
'''下面是isinstance用法'''
a=10
isinstance(a, int)
>>> True
isinstance(a, (int,str))
>>> True
'''下面是type用法'''
type(a)
>>> <class 'int'>
type(a) == int
>>> True
is 与 ==
- 先上个例子
a=[1,2,3]
b=[1,2,3]
a==b
>>> True
a is b
>>> False
解释,python中变量都是引用(C/C++中指针的含义),因此a有两层含义
- 第一层,该变量是一个引用,是指向一块内存的指针,因此a,b指向了两块内存(虽然值一样)。
- 第二层,两个变量指向内存中存储的值
id(a)
>>> 2321066859776
id(b)
>>> 2321066887424
- 上述例子表明,虽然他们的值相同,但是在内存中指向的位置不同。
- 说了那么多,该说重点了
- “==” 主要是两个引用指向的值相同就可以了,即指向的内容相同,这就是“相等”的含义
- “is” 顾名思义就是是的意思,同时需要满足两个条件,第一:指向的内存位置相同,第二:内存中放的值也相同。因此,is的条件更加严苛一些。
- 这也就是我们判断变量的时候,通常只用“==”的原因了。