您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Python面向對象程序設計的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Python面向對象程序設計的示例分析”這篇文章吧。
使用@staticmethod來定義靜態方法。
靜態方法:類和實例都可以調用的方法,實際上跟類沒什么關系了,對于這種不太相關的就使用靜態方法【用實例和類調用沒有區別】
class Dog(object): def __init__(self,name): self.name=name def talk(self): print("%s is talking"%self.name) @staticmethod def eat(self,food):## print("%s is eating %s"%(self.name,food)) @staticmethod def bulk(): ##如果不涉及實例變量的內容,可以不傳self print("wang wang!") d=Dog("haha") d.talk() Dog.eat(d,"baozi") d.eat(d,"mianbao") d.bulk() Dog.bulk()
注:由于不太相關,所以不會自動傳self,如果操作涉及對象的內容,需要手動傳入
使用@classmethod來定義類方法
類方法只能訪問類變量,不能訪問實例變量
如果涉及類變量比較多,而涉及實例變量比較少的話,使用類方法
class Dog(object): name="haha" def __init__(self,name): self.name=name @classmethod def eat(self): print(self)# <class '__main__.Dog'> 說明self是一個類 print("%s is eating "%self.name)#所以只會調用類中的name d=Dog("aotuman") d.eat()##haha is eating Dog.eat()##haha is eating d2=Dog("huluwa") d2.eat()
注:類方法中的self是一個類,因此才會只訪問類變量
@property會把一個方法變成一個屬性
為什么會有屬性方法
現有需求:我輸入因數,你就會打印出我要的計算結果
用變量來實現:
缺點:無法約束賦值,假如我要限制不能輸入非數字【實際上,如果要做這樣的約束,就要建立一個函數,這實際上與屬性方法相同,而如果在my_sum里面檢測的話,就比建立一個函數還要麻煩了】
用屬性方法來實現:
代碼:
解釋:
@property用于獲取;@setter用于賦值傳參;@deleter用于刪除屬性,并不影響其他與當前@property無關的函數
要想他們三個關聯起來,函數名必須相同,且前綴是@property修飾的函數的名
class calc: @property def my_sum(self): print(self.one+self.two) @my_sum.setter def my_sum(self,l): if isinstance(l[0],int)&isinstance(l[1],int): self.one=l[0] self.two=l[1] else: print("no int") @my_sum.deleter def my_sum(self): print("del done") del self.one,self.two c=calc() c.my_sum=[1,2] c.my_sum del c.my_sum
以上是“Python面向對象程序設計的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。