1. 程式人生 > >高級語法

高級語法

去掉 osi src ssi cme ttr back lai attribute

通過@staticmethod裝飾器即可把其裝飾的方法變為一個靜態方法,什麽是靜態方法呢?其實不難理解,普通的方法,可以在實例化後直接調用,並且在方法裏可以通過self.調用實例變量或類變量,但靜態方法是不可以訪問實例變量或類變量的,一個不能訪問實例變量和類變量的方法,其實相當於跟類本身已經沒什麽關系了,它與類唯一的關聯就是需要通過類名來調用這個方法

1 2 3 4 5 6 7 8 9 10 11 12 13 class Dog(object): def __init__(self,name): self.name = name @staticmethod
#把eat方法變為靜態方法 def eat(self): print("%s is eating" % self.name) d = Dog("ChenRonghua") d.eat()

上面的調用會出以下錯誤,說是eat需要一個self參數,但調用時卻沒有傳遞,沒錯,當eat變成靜態方法後,再通過實例調用時就不會自動把實例本身當作一個參數傳給self了。

1 2 3 4 Traceback (most recent call last): File "/Users/jieli/PycharmProjects/python基礎/自動化day7面向對象高級/靜態方法.py"
, line 17, in <module> d.eat() TypeError: eat() missing 1 required positional argument: ‘self‘

想讓上面的代碼可以正常工作有兩種辦法

1. 調用時主動傳遞實例本身給eat方法,即d.eat(d)

2. 在eat方法中去掉self參數,但這也意味著,在eat中不能通過self.調用實例中的其它變量了

技術分享圖片
 1 class Dog(object):
 2 
 3     def __init__(self,name):
 4         self.name = name
 5 
 6     @staticmethod
 7     def eat():
 8         print(" is eating")
 9 
10 
11 
12 d = Dog("ChenRonghua")
13 d.eat()
技術分享圖片

類方法  

類方法通過@classmethod裝飾器實現,類方法和普通方法的區別是, 類方法只能訪問類變量,不能訪問實例變量

1 2 3 4 5 6 7 8 9 10 11 12 class Dog(object): def __init__(self,name): self.name = name @classmethod def eat(self): print("%s is eating" % self.name) d = Dog("ChenRonghua") d.eat()

執行報錯如下,說Dog沒有name屬性,因為name是個實例變量,類方法是不能訪問實例變量的

1 2 3 4 5 6 Traceback (most recent call last): File "/Users/jieli/PycharmProjects/python基礎/自動化day7面向對象高級/類方法.py", line 16, in <module> d.eat() File "/Users/jieli/PycharmProjects/python基礎/自動化day7面向對象高級/類方法.py", line 11, in eat print("%s is eating" % self.name) AttributeError: type object ‘Dog‘ has no attribute ‘name‘

此時可以定義一個類變量,也叫name,看下執行效果

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 class Dog(object): name = "我是類變量" def __init__(self,name): self.name = name @classmethod def eat(self): print("%s is eating" % self.name) d = Dog("ChenRonghua") d.eat() #執行結果 我是類變量 is eating

高級語法