Python 字符串池化的前提
前言
在 Python 中經(jīng)常通過內(nèi)存池化技術(shù)來提高其性能,那么問題來了,在什么情況下會池化呢? 讓我們通過幾個例子進(jìn)行一下理解一下.
預(yù)備知識
在查看例子之前,首先要提 python 中的一個函數(shù) id(),讓我們看一下函數(shù)說明:
id(obj, /) Return the identity of an object. This is guaranteed to be unique among simultaneously existing objects. (CPython uses the object \'s memory address.)
通過上述說明,可以得知 id() 將會返回對像的唯一標(biāo)識,在 CPython 中將會返回內(nèi)存地址,也就是說如果兩個對象 的 id 值一樣,可以說著兩個對象是相同的了.
例子
example 00
a = "" b = "" print(id(a),id(b)) print(a is b)
輸出結(jié)果:
>>> a = ""
>>> b = ""
>>> print(id(a),id(b))
2114853370544 2114853370544
>>> print(a is b)
True
example 01
a = "a" b = "a" print(id(a),id(b)) print(a is b)
輸出結(jié)果:
>>> a = "a"
>>> b = "a"
>>> print(id(a),id(b))
2114883022608 2114883022608
>>> print(a is b)
True
example 02
a = "magic_string" b = "magic" + "_" + "string" print(id(a),id(b)) print(a is b)
輸出結(jié)果:
>>> a = "magic_string"
>>> b = "magic" + "_" + "string"
>>> print(id(a),id(b))
2114887161136 2114887161136
>>> print(a is b)
True
example 03
a = "magic!" b = "mgaic!" print(id(a),id(b)) print(a is b)
輸出結(jié)果:
>>> a = "magic!"
>>> b = "mgaic!"
>>> print(id(a),id(b))
2114885855416 2114889455408
>>> print(a is b)
False
example 04
a,b = "magic!","magic!" print(id(a),id(b)) print(a is b)
輸出結(jié)果:
>>> a,b = "magic!","magic!"
>>> print(id(a),id(b))
2114885691912 2114885691912
>>> print(a is b)
True
example 05
a = "!" b = "!" print(id(a),id(b)) print(a is b)
輸出結(jié)果:
>>> a = "!"
>>> b = "!"
>>> print(id(a),id(b))
140564571922024 140564571922024
>>> print(a is b)
True
example 06
print(a*20 is 'aaaaaaaaaaaaaaaaaaaa') print(a*21 is 'aaaaaaaaaaaaaaaaaaaaa')
輸出結(jié)果:
>>> print(a*20 is 'aaaaaaaaaaaaaaaaaaaa')
False
>>> print(a*21 is 'aaaaaaaaaaaaaaaaaaaaa')
False
總結(jié)
通過上述 7 個例子,我們不難對 python 的字符串池化有個大概的認(rèn)識,我們這里做個簡單的總結(jié):
- 通過 example 00,01,05,我們可以得出對于長度為 0 或者 1 的字符串會被池化
- 通過 example 02,03,我們可以得出字符串中只包含字母數(shù)字以及下劃線的字符串會被池化
- 通過 example 04, 我們可以得出當(dāng)在同一行對不同變量,賦值如果相同的話,它們將會指向同一個對象,注意這里面的 “magic!” 并不符合池化的要求,這只是一種編譯器的優(yōu)化
- example 06 所出現(xiàn)的現(xiàn)象在 python 中有一個專業(yè)的術(shù)語,講常量折疊(constant folding),顧名思義,在編譯優(yōu)化時,講能夠計算出的結(jié)果的變量直接替換為常量.但是這沒有限制嗎?顯然不是的,在我們的例子中已經(jīng)發(fā)現(xiàn),當(dāng)長度超過20的時候,折疊就會失效了,試想一下,如果沒有限制的話,初始化的字符串過長,將會嚴(yán)重導(dǎo)致性能的下降以及內(nèi)存的消耗
參考鏈接
The internals of Python string interning
Python String objects implementation
以上就是Python 字符串池化的前提的詳細(xì)內(nèi)容,更多關(guān)于Python 字符串池化的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
使用python實現(xiàn)strcmp函數(shù)功能示例
這篇文章主要介紹了使用python實現(xiàn)strcmp函數(shù)功能的示例,需要的朋友可以參考下2014-03-03Python3將數(shù)據(jù)保存為txt文件的方法
這篇文章主要介紹了Python3將數(shù)據(jù)保存為txt文件的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09python smtplib模塊實現(xiàn)發(fā)送郵件帶附件sendmail
這篇文章主要為大家詳細(xì)介紹了python smtplib模塊實現(xiàn)發(fā)送郵件帶附件sendmail,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05