本文目錄一覽:
- 1、python類中self參數和cls參數
- 2、python中cls關鍵字
- 3、python中的cls到底指的是什麼,與self有什麼區別
- 4、Python 面試高頻問題:cls到底是什麼
- 5、什麼時候使用python類cls方法
python類中self參數和cls參數
self:表示一個類的實例對象本身
輸出:
a .fun_one() = A .fun_one( a ) 二者是等價的;
cls :所指的就是這個類本身
python中cls關鍵字
類內有三種方法
@staticmethod
def func1(num)
def func2(self, num)
@classmethod
def func3(cls, num)
靜態成員方法func1和普通成員方法func2的區別是,靜態成員方法可以不實例化,直接被類名+方法名調用;普通成員方法必須被實例化之後的對象調用。
靜態成員方法func1和類成員方法func3的相同點是二者都可以直接通過類名+方法名的方式調用,不同點是可以func3通過cls.func2()在func3內部調用func2,但是func1中不能調用func2,func1隻能得到類的屬性。
python中的cls到底指的是什麼,與self有什麼區別
一般來說,在Python中,類實例屬性的訪問規則算是比較直觀的。
但是,仍然存在一些不是很直觀的地方,特別是對C++和Java程序員來說,更是如此。
在這裡,我們需要明白以下幾個地方:
1.Python是一門動態語言,任何實體都可以動態地添加或刪除屬性。
2.一個類定義了一個作用域。
3.類實例也引入了一個作用域,這與相應類定義的作用域不同。
4.在類實例中查找屬性的時候,首先在實例自己的作用域中查找,如果沒有找到,則再在類定義的作用域中查找。
5.在對類實例屬性進行賦值的時候,實際上會在類實例定義的作用域中添加一個屬性(如果還不存在的話),並不會影響到相應類中定義的同名屬性。
下面看一個例子,加深對上述幾點的理解:
複製代碼
代碼如下:
class A:
cls_i = 0
cls_j
= {}
def __init__(self):
self.instance_i =
self.instance_j =
{}
在這裡,我們先定義類A的一個實例a,然後再看看類A的作用域和實例a的作用域中分別有什麼:
複製代碼
代碼如下:
a = A()
a.__dict__
{‘instance_j’: {}, ‘instance_i’: 0}
A.__dict__
{‘__init__’: , ‘__module__’: ‘__main__’, ‘cls_i’: 0, ‘cls_j’: {},
‘__doc__’: None}
我們看到,a的作用域中有instance_i和instance_j,A的作用域中有cls_i和cls_j。
我們再來看看名字查找是如何發生的:
複製代碼
代碼如下:
a.cls_i
a.instance_i
在查找cls_i的時候,實例a的作用域中是沒有它的,卻在A的作用域中找到了它;在查找instance_i的時候,直接可在a的作用域中找到它。
如果我們企圖通過實例a來修改cls_i的值,那會怎樣呢:
複製代碼
代碼如下:
a.cls_i = 1
a.__dict__
{‘instance_j’: {}, ‘cls_i’: 1, ‘instance_i’: 0}
A.__dict__
{‘__init__’: , ‘__module__’: ‘__main__’, ‘cls_i’: 0, ‘cls_j’: {},
‘__doc__’: None}
我們可以看到,a的作用域中多了一個cls_i屬性,其值為1;同時,我們也注意到A作用域中的cls_i屬性的值仍然為0;在這裡,我們其實是增加了一個實例屬性,並沒有修改到類屬性。
如果我們通過實例a操縱cls_j中的數據(注意不是cls_j本身),又會怎麼樣呢:
複製代碼
代碼如下:
a.cls_j[‘a’] =
‘a’
a.__dict__
{‘instance_j’: {}, ‘cls_i’: 1, ‘instance_i’:
0}
A.__dict__
{‘__init__’: , ‘__module__’: ‘__main__’,
‘cls_i’: 0, ‘cls_j’: {‘a’: ‘a’}, ‘__doc__’: None}
我們可以看到a的作用域沒有發生什麼變化,但是A的作用域發生了一些變化,cls_j中的數據發生了變化。
實例的作用域發生變化,並不會影響到該類的其它實例,但是類的作用域發生變化,則會影響到該類的所有實例,包括在這之前創建的實例:
複製代碼
代碼如下:
A.cls_k = 0
Python 面試高頻問題:cls到底是什麼
上一篇文章介紹了什麼是python 中的self,詳情請參考:
Python面試高頻問題:self到底是什麼
簡單的說self是類(Class)實例化的對象。
面試中還有一個問題經常被提及,那就是——什麼是cls呢?
cls 是類(或子類)本身,取決於調用的是哪個類。
看下面的實例
輸出:
我們也可以通過實例的方法調用class method,例如:
同樣輸出
輸出:
使用cls 作為方法參數時,通常該方法需要由@classmethod 修飾,@classmethod修飾的方法表示的是類方法。這裡需要注意cls就是一個標識,你可以把他寫成abc,bcd都是可以的,只是出於習慣寫成了cls。
既然cls是一個類,那麼我們就可以使用他來進行實例化,具體代碼如下:
輸出:
可以看到通過obj1=cls()和obj2=cls(),成功創建了兩個實例,分別是0x000000690A1E0C08和0x000000690A1E0C48,而這兩個實例的類型都是MyClass3′
另外cls 還可以在python類中的方法 __new__里實現,通常定義為:
最後我們可以簡單地總結一下self 和 cls:簡單的說self是類(Class)實例化的對象。
cls 是類(或子類)本身。我們也可以方便地理解self表示實例的,cls則表示類的!
什麼時候使用python類cls方法
cls是class的縮寫。
class A:
member = “this is a test.”
def __init__(self):
pass
@classmethod
def Print1(cls):
#榪欎釜鏄被鏂規硶
print “print 1: “, cls.member
def Print2(self):
print “print 2: “, self.member
@classmethod
def Print3(paraTest):
print “print 3: “, paraTest.member
a = A()
A.Print1() #相當於Print1(A)
a.Print2() #相當於Print2(a), 請注意@classmethod
A.Print3()
可以看出來,python在通過“.”調用成員函數的時候,會將“.”前面的東西當作函數的第一個參數調用。
而且pyhon並不關心我們把類的成員函數的第一個參數的名稱是什麼,我們可以用任意的名稱,可以看Print3的定義就知道了。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/291106.html