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能避免非限定調用造成的全局變量。
在Python3之後不知道將self隱了沒?感覺在Python類裏的方法都要帶個self這樣有點死板
首先明確的是self只有在類的方法中纔會有,獨立的函數或方法是不必帶有self的。self在定義類的方法時是必須有的,雖然在調用時不必傳入相應的參數。
self名稱不是必須的,在python中self不是關鍵詞,你可以定義成a或b或其它名字都可以,但是約定成俗,不要搞另類,大家會不明白的。下例中將self改爲myname一樣沒有錯誤:
1 class Person: 2 def _init_(myname,name): 3 myname.name=name 4 def sayhello(myname): 5 print 'My name is:',myname.name 6 p=Person('Bill') 7 print p
self指的是類實例對象本身(注意:不是類本身)。
1 class Person: 2 def _init_(self,name): 3 self.name=name 4 def sayhello(self): 5 print 'My name is:',self.name 6 p=Person('Bill') 7 print p
在上述例子中,
self
指向Person的實例p。 爲什麼不是指向類本身呢,如下例子:
1 class Person: 2 def _init_(self,name): 3 self.name=name 4 def sayhello(self): 5 print 'My name is:',self.name 6 p=Person('Bill') 7 p1 = Person('Apple') 8 print p