爲什麼Python沒有屬性賦值的“with”語句?

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在運行時解析名稱綁定,而第二個版本只需要執行一次解析。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章