概述
Python中的增強賦值是從C語言中借鑒出來的,所以這些格式的用法大多和C一致,本身就是對表達式的簡寫,即二元表達式和賦值語句的結(jié)合,比如a += b 和a = a + b 就是一致的,比如還有以下的增強賦值語句。
即增強賦值語句適用于任何支持隱式二元表達式的類型,比如“+”的多態(tài):數(shù)字的相加和字符串的合并
數(shù)字加減
a = 1a = a + 1print(str(a))a += 1print(str(a))
示例結(jié)果:
23
字符串合并
S = 'I'S = S + ' like 'print(S)S += 'Python.'print(S)
示例結(jié)果:
I likeI like Python.
優(yōu)點
簡潔
減少一次a的執(zhí)行,執(zhí)行速度更快
針對可變對象,增強賦值會自動選擇執(zhí)行原處的修改運算,而不是速度更慢的復(fù)制。這就引申出我們在可變對象中可能涉及的共享引用問題。
共享引用
當(dāng)我們想要擴展列表時,比如將一組元素添加到末尾,我們會怎么做?
L = [1, 2, 3]# 傳統(tǒng)“+”法L = L + [4, 5]print(L)# 利用列表方法extendL.extend([6, 7])print(L)
示例結(jié)果
[1, 2, 3, 4, 5][1, 2, 3, 4, 5, 6, 7]
示例中第一中“+”法,即采用合并的方法,需要新創(chuàng)建一個對象把左側(cè)的L復(fù)制到新列表中,然后再[4, 5]復(fù)制到新列表中。而第二種extend則是直接在內(nèi)存空間列表L末尾L加上[4, 5],即速度會更快,增強賦值則是自動采用的第二種即L.extend([6, 7])和L += [6, 7]是等價的,也是最優(yōu)的選擇。這種合并方式雖然快,但對于可變對象的共享引用則會變的棘手些。
L1 = [1, 2, 3]L2 = L1L2 = L2 + [4, 5]print(L2)print(L1)print('-' * 21)L1 = [1, 2, 3]L2 = L1L2 += [4, 5]print(L2)print(L1)
示例結(jié)果:
[1, 2, 3, 4, 5][1, 2, 3]---------------------[1, 2, 3, 4, 5][1, 2, 3, 4, 5]
我們可以從示例中看到如果同一個可變對象賦值了多個變量,那么在破壞共享引用結(jié)構(gòu)時,就應(yīng)該對可變對象拷貝后在進行操作。