python中self _init_(self,param1,param2)問題
問題描述
昨天的self _init_(self,param1,param2)問題class Ball:
def setName(tt,name): tt.name=namedef kick(tt): print(’我是%s,該死的,誰踢我...’%tt.name)
a=Ball()a.setName(’球A’)b=Ball()b.setName(’球B’)c=Ball()c.setName(’球C’)a.kick()c.kick()將self改為其他變量名tt不影響結果
class Ball:
def __init__(self,name): self.name=namedef kick(self): print(’我是%s,該死的,誰踢我...’%self.name)
b=Ball(’土豆’)b.kick()c=Ball(’黃瓜’)c.kick()注意:_init__(self,name)這個構造函數的左右下劃線都是兩個。固定格式,不然會報錯TypeError: object() takes no parameters 類型錯誤:對象不接受參數。前后對比發現是直接調用Ball的,相當于類Ball的自身函數。__init__()是類的構造函數,在建立對象時調用。self是對“對象”自身的引用。內部函數調用,用于初始化對象。class Ball:
def __init__(tt,name): tt.name=namedef kick(tt): print(’我是%s,該死的,誰踢我...’%tt.name)
b=Ball(’土豆’)b.kick()c=Ball(’黃瓜’)c.kick()把self換成其他變量名發現結果不變?那改與不改究竟有撒區別呢?請理論+實例講解下。class Person:
name=’小甲魚’
p=Person()print(p.name)
class Person:
__name=’小甲魚’
p=Person()print(p._Person__name)
從外部訪問這個變量了,Python在類的內部用_classname__spam替換了__spam,參考http://blog.csdn.net/doufei_c... http://blog.csdn.net/gudeshen...懂Python的朋友都知道Python把以兩個或以上下劃線字符開頭且沒有以兩個或以上下劃線結尾的變量當作私有變量。私有變量會在代碼生成之前被轉換為長格式(變為公有)。轉換機制是這樣的:在變量前端插入類名,再在前端加入一個下劃線字符。這就是所謂的私有變量軋壓(Private name mangling)。如類A里的__private標識符將被轉換為_A__private,這就是上一節出現_A__private和__private消失的原因了。Python為了保證不能再class之外訪問該變量,,Python會在類的內部自動的把你定義的__spam變量的名字替換成為 _classname__spam(注意,classname前面是一個下劃線,spam前是兩個下劃線),Python把這種技術叫做“name mangling”。因此,用戶在外部訪問__spam的時候就會提示找不到相應的變量。解釋下用途 區別
問題解答
回答1:你是要問什么?不太明白哈~
回答2:永遠不要那么訪問 教程只是為了告訴你底層如何實現的
回答3:http://greybeard.iteye.com/bl...http://python3-cookbook.readt...
這兩個鏈接可能可以解答你的疑問
回答4:特殊變量命名
1、 _xx 以單下劃線開頭的表示的是protected類型的變量。即保護類型只能允許其本身與子類進行訪問。若內部變量標示,如: 當使用“from M import”時,不會將以一個下劃線開頭的對象引入 。
2、 __xx 雙下劃線的表示的是私有類型的變量。只能允許這個類本身進行訪問了,連子類也不可以用于命名一個類屬性(類變量),調用時名字被改變(在類FooBar內部,__boo變成_FooBar__boo,如self._FooBar__boo)
3、 __xx__定義的是特列方法。用戶控制的命名空間內的變量或是屬性,如init , __import__或是file 。只有當文檔有說明時使用,不要自己定義這類變量。 (就是說這些是python內部定義的變量名)
