目录
神奇的intern机制
哪些情况下不需要续行符?
用户无感知的小整数池
神奇的intern机制
字符串类型作为Python中最常用的数据类型之一,Python解释器为了提高字符串使用的效率和使用性能,做了很多优化.
例如:Python解释器中使用了intern(字符串驻留)的技术来提高字符串效率,什么是intern机制?就是同样的字符串对象仅仅会保存一份,放在一个字符串储蓄池中,是共用的,当然,肯定不能改变,这也决定了字符串必须是不可变对象。
>>> s1="hello" >>> s2="hello" >>> s1 is s2 True # 如有空格,默认不启用intern机制 >>> s1="hell o" >>> s2="hell o" >>> s1 is s2 False # 如果一个字符串长度超过20个字符,不启动intern机制 >>> s1 = "a" * 20 >>> s2 = "a" * 20 >>> s1 is s2 True >>> s1 = "a" * 21 >>> s2 = "a" * 21 >>> s1 is s2 False >>> s1 = "ab" * 10 >>> s2 = "ab" * 10 >>> s1 is s2 True >>> s1 = "ab" * 11 >>> s2 = "ab" * 11 >>> s1 is s2 False
哪些情况下不需要续行符?
在写代码时,为了代码的可读性,代码的排版是尤为重要的。
为了实现高可读性的代码,我们常常使用到的就是续行符。
>>> a ='talk is cheap,' ... 'show me the code.' >>> >>> print(a) talk is cheap,show me the code.
那有哪些情况下,是不需要写续行符的呢?
经过总结,在这些符号中间的代码换行可以省略掉续行符:,,。
>>> my_list=[1,2,3, ... 4,5,6]
>>> my_tuple=(1,2,3, ... 4,5,6)
>>> my_dict={"name": "MING",
... "gender": "male"}
另外还有,在多行文本注释中,续行符也是可以不写的。
>>> text = '''talk is cheap, ... show me the code'''
用户无感知的小整数池
为避免整数频繁申请和销毁内存空间,Python定义了一个小整数池[-5,256]这些整数对象是提前建立好的,不会被垃圾回收。
以上代码请在终端Python环境下测试,如果你是在IDE中测试,由于IDE的影响,效果会有所不同。
>>> a = -6 >>> b = -6 >>> a is b False >>> a = 256 >>> b = 256 >>> a is b True >>> a = 257 >>> b = 257 >>> a is b False >>> a = 257; b = 257 >>> a is b True
问题又来了:最后一个示例,为啥是True?
因为当你在同一行里,同时给两个变量赋同一值时,解释器知道这个对象已经生成,那么它就会引用到同一个对象。如果分成两成的话,解释器并不知道这个对象已经存在了,就会重新申请内存存放这个对象。



