Python二元賦值實用技巧解析

2022-10-04 15:57:25 字數 994 閱讀 5664

python支援類似於a += 3這種二元表示式。比如:

a += 3 -> a = a + 3

a -= 3 -> a = a - 3

a *= 3 -> a = a * 3

...在python中的某些情況下,這種二元賦值表示式可能比普通的賦值方umdpddmmd式效率更高些。原因有二:

二元賦值表示式中,a可能會是乙個表示式,它只需計算評估一次,而a = a + 3中,a要計算兩次。

對於可變物件,可以直接在原處修改得到修改後的值,而普通的一元賦值表示式必須在記憶體中新建立乙個修改後的資料物件,並賦值給變數

第一點無需解釋。關於第二點,看下面的例子:

l = [1,2,3]

l = l + [4] # (1):慢

l += [4] # (2):快

l.append(4) # (3):快,等價於(2)

l = l + [5,6] # (4):慢

l += [5,6] # (5):快

l.extend([5,6]) # (6):快,等價於(5)

對於上面(1)和(4)的一元賦值表示式,先取得l,然後建立乙個新的列表物件,將l拷貝到新列表物件中,並將4或5,6放進新列表物件,最後賦值給l。這個過程中涉及到了幾個步驟:新分配記憶體、記憶體中列表拷貝、放入新資料。

而(2)(3)是等價的,(5)(6)也是等價的,它們都是直接在記憶體中的原始列表處修改,不會有拷貝操作,新建的資料物件僅僅只是乙個umdpddmmd元素。

按照理論上來說,確實二元賦值方式要效率高一些,但要注意的是,列表中儲存的只是各元素的引用,所以拷貝列表也僅僅只是拷貝一點引用,這是微乎其微的開銷。所以一元賦值和二元賦值的差距在這一點的效能上基本沒差距,主要的umdpddmmd差距還在於一元、二元賦值方式可能存在的表示式不同評估次數。

總的來說,使用二元賦值表示式通常可以作為可變物件賦值的一種優化手段。

本文標題: python二元賦值實用技巧解析

本文位址: /jiaoben/python/282759.html

Python實用技巧

1 改變工作目錄 1 import os2 os.chdir c users mr.zhao 2 搜尋制定目錄下的檔案 1 import glob 2 glob.glob c user mr.zhao csv 3 對字典進行排序 1 dict test 2 sorted dict test.item...

C 實用技巧(二)

上一篇文章講到了如何檢查記憶體洩露。其實只要肯用c 的stl裡面的高階功能的話,記憶體洩露是很容易避免的。我在開發vczh library 3.0的時候,所有的測試用例都保證跑完了沒有記憶體洩露。但是很可惜有些c 團隊不能使用異常,更甚者不允許寫建構函式析構函式之類,前乙個還好,後乙個簡直就是在用c...

python實用技巧(一)

python實用技巧 一 python實用技巧 二 python實用技巧 三 python實用技巧 四 已知x是多維陣列型別,則 在作業系統 windows或者linux 命令列介面下 python v python 3.4 3 anaconda 2.3.0 32 bit 如果我們已經進行pytho...