原文位址:http://sjolzy.cn/Why-should-self-Python.html
Python要self的理由
Python的類的方法和普通的函數有一個很明顯的差別,在類的方法必須有個額外的第一個參數 (self ),但在調用這個方法的時候不必為這個參數指派 (顯勝于隐 的引發)。Python的類的方法的這個特别的參數指代的是對象本身,而按照Python的慣例,它用self來表示。(當然我們也可以用其他任何名稱來代替,隻是規範和标準在那建議我們一緻使用self)
為何Python給self指派而你不必給self指派?
例子說明:建立了一個類MyClass,執行個體化MyClass得到了MyObject這個對象,然後調用這個對象的方法MyObject.method(arg1,arg2) ,這個過程中,Python會自動轉為Myclass.mehod(MyObject,arg1,arg2)
這就是Python的self的原理了。即使你的類的方法不需要任何參數,但還是得給這個方法定義一個self參數,雖然我們在執行個體化調用的時候不用理會這個參數不用給它指派。
執行個體:
class Python:
def selfDemo(self):
print('Python,why self?')
p = Python()
p.selfDemo()
輸出:Python,why self?
把p.selfDemo()帶個參數如:p.selfDemo(p),得到同樣的輸出結果
如果把self去掉的話,
class Python:
def selfDemo():
print('Python,why self?')
p = Python()
p.selfDemo()
這樣就報錯了:TypeError: selfDemo() takes no arguments (1 given)
擴充
self在Python裡不是關鍵字。self代表目前對象的位址,self 其實就是class中instance,譬如static method 是不需要加self的, 譬如non-static method 有時候用className.method() 也是可以的。self能避免非限定調用造成的全局變量。