Python有一個 'with' 語句,它封裝了塊的執行,在塊的入口和出口調用代碼。有些語言的結構是這樣的:
a = 1 # equivalent to obj.a = 1
total = total + 1 # obj.total = obj.total + 1
在Python中,這樣的結構是不明確的。
其他語言,如ObjectPascal、Delphi和C++ 使用靜態類型,因此可以毫不含糊地知道分配給什麼成員。這是靜態類型的要點 -- 編譯器 總是 在編譯時知道每個變量的python 作用域。
Python使用動態類型。事先不可能知道在運行時引用哪個屬性。可以動態地在對象中添加或刪除成員屬性。這使得無法通過簡單的閱讀就知道引用的是什麼屬性:局部屬性、全局屬性還是成員屬性?
例如,採用以下不完整的代碼段:
with a:
print(x)
該代碼段假設 "a" 必須有一個名爲 "x" 的成員屬性。然而,Python中並沒有告訴解釋器這一點。假設 "a" 是整數,會發生什麼?如果有一個名爲 "x" 的全局變量,它是否會在with塊中使用?如您所見,Python的動態特性使得這樣的選擇更加困難。
然而,Python 可以通過賦值輕鬆實現 "with" 和類似語言特性(減少代碼量)的主要好處。代替:
function(args).mydict[index][index].b = 42
function(args).mydict[index][index].c = 63
寫成這樣:
ref.a = 21
ref.b = 42
ref.c = 63
這也具有提高執行速度的副作用,因爲Python在運行時解析名稱綁定,而第二個版本只需要執行一次解析。