先看下面这段代码
-
>>> a =
'apple'
-
>>> b =
'apple'
-
>>> a is b
-
True
返回结果看起来没毛病
再来看这段:
-
>>> a =
'apple!'
-
>>> b =
'apple!'
-
>>> a is b
-
False
这个结果是不是有点诡异
前后两个字符串仅仅是一字之差,结果完全不同。
不信你可以自己测试一下
为了理解这段代码的区别,里面涉及到一个概念,叫做“字符串驻留”,英文叫string intern。
什么是字符串驻留
python中万物皆对象,某些情况下,解释器遇到两个看起来长的一毛一样的对象时会做一些优化
例如上面例子中的第一段代码,a 和 b 的值都是 apple
,当解释器准备创建第二个字符串”apple”时,解释器会去驻留内存中查找是否已经存在“apple”对象,如果有就不在创建新的对象了,两人共享一个老婆,哦不对,是共享一个对象。
这就是字符串驻留的概念。
所以 a 和 b 这两个变量共享了同一个对象,因此 is
运算后返回结果为 True
。
对于简单的字符串,系统中可能大量重复存在,这样的好处就是节省内存。驻留内存这个策略在java中也存在。
但并不是所有的字符串有会放进驻留内存中,如果都驻留的话,内存会爆炸。只有符合如下规则才有可能被驻留
长度为 0 或者 1 的字符串被驻留.
字符串中只包含字母,数字或下划线时将会驻留。
字符串必须是编译时的常量字符串
例如下面的c用join方法生成的字符串就不会驻留
-
>>> a =
"apple"
-
>>> c =
"".join([
'a',
'p',
'p',
'l',
'e'])
-
>>> a is c
-
False
这种驻留机制好像在实际应用中并没什么卵用,为什么我们还是要了解呢?至少我们在面试的时候可以 装下逼啊。。。
关注我,每天给你讲点python知识
不嫌麻烦的话,帮你点个在看,谢谢啦
转载:https://blog.csdn.net/lantian_123/article/details/106309043
查看评论