亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python在什么情況下字符串會池化

發布時間:2020-07-06 11:28:12 來源:億速云 閱讀:119 作者:清晨 欄目:開發技術

小編給大家分享一下Python 字符串池化的前提,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

前言

在 Python 中經常通過內存池化技術來提高其性能,那么問題來了,在什么情況下會池化呢; 讓我們通過幾個例子進行一下理解一下.

預備知識

在查看例子之前,首先要提 python 中的一個函數 id(),讓我們看一下函數說明:

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() 將會返回對像的唯一標識,在 CPython 中將會返回內存地址,也就是說如果兩個對象 的 id 值一樣,可以說著兩個對象是相同的了.

例子

example 00

a = ""
b = ""
print(id(a),id(b))
print(a is b)

輸出結果:

>>> 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)

輸出結果:

>>> 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)

輸出結果:

>>> 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)

輸出結果:

>>> 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)

輸出結果:
>>> 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)

輸出結果:

>>> 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')

輸出結果:

>>> print(a*20 is 'aaaaaaaaaaaaaaaaaaaa')
False
>>> print(a*21 is 'aaaaaaaaaaaaaaaaaaaaa')
False


通過上述 7 個例子,我們不難對 python 的字符串池化有個大概的認識,我們這里做個簡單的總結:

  1. 通過 example 00,01,05,我們可以得出對于長度為 0 或者 1 的字符串會被池化
  2. 通過 example 02,03,我們可以得出字符串中只包含字母數字以及下劃線的字符串會被池化
  3. 通過 example 04, 我們可以得出當在同一行對不同變量,賦值如果相同的話,它們將會指向同一個對象,注意這里面的 “magic!” 并不符合池化的要求,這只是一種編譯器的優化
  4. example 06 所出現的現象在 python 中有一個專業的術語,講常量折疊(constant folding),顧名思義,在編譯優化時,講能夠計算出的結果的變量直接替換為常量.但是這沒有限制嗎?顯然不是的,在我們的例子中已經發現,當長度超過20的時候,折疊就會失效了,試想一下,如果沒有限制的話,初始化的字符串過長,將會嚴重導致性能的下降以及內存的消耗。
    看完了這篇文章,相信你對Python 字符串池化的前提有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

秦皇岛市| 东光县| 营口市| 塔河县| 莲花县| 德惠市| 成武县| 晴隆县| 云霄县| 沅陵县| 芷江| 洪雅县| 安平县| 福清市| 楚雄市| 思茅市| 连平县| 玉林市| 郧西县| 石渠县| 昌黎县| 银川市| 高淳县| 浦东新区| 中山市| 靖西县| 内黄县| 浮梁县| 开鲁县| 阿坝县| 商丘市| 凌海市| 阜南县| 高唐县| 元氏县| 新蔡县| 建平县| 瑞丽市| 疏附县| 南皮县| 亳州市|