高級語法
阿新 • • 發佈:2018-05-14
去掉 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
|
高級語法