我們已經接觸過函式(function)的引數(arguments)傳遞。當時我們根據位置,傳遞對應的引數。我們將接觸更多的引數傳遞方式。
回憶一下位置傳遞:
def f(a,b,c):
return a+b+c
print(f(www.cppcns.com1,2,3))
在呼叫f時,1,2,3根據位置分別傳遞給了a,b,c。
關鍵字傳遞
有些情況下,用位置傳遞會感覺比較死板。關鍵字(keyword)傳遞是根據每個引數的名字傳遞引數。關鍵字並不用遵守位置的對應關係。依然沿用上面f的定義,更改呼叫方式:
print(f(c=3,b=2,a=1))
關鍵字傳遞可以和位置傳遞混用。但位置引數要出現在關鍵字引數之前:
print(f(1,c=3,b=2))
引數預設值
在定義函式的時候,使用形如a=19的方式,可以給引數賦予預設值(default)。如果該引數最終沒有被傳遞值,將使用該預設值。
def f(a,b,cejqxqllwob=10):
return a+b+c
print(f(3,2))
print(f(3,2,1))
在第一次呼叫函式f時, 我們並沒有足夠的值,c沒有被賦值,c將使用預設值10.
第二次呼叫函式的時候,c被賦值為1,不再使用預設值。
包裹傳遞
在定義函式時,我們有時候並不知道呼叫的時候會傳遞多少個引數。這時候,包裹(packing)位置引數,或者包裹關鍵字引數,來進行引數傳遞,會非常有用。
下面是包裹位置傳遞的例子:
程式設計客棧def func(*name):
print type(name)
print name
func(1,4,6)
func(5,6,7,1,2,3)www.cppcns.com
兩次呼叫,儘管引數個數不同,都基於同乙個func定義。在func的參數列中,所有的引數被name收集,根據位置合併成乙個元組(tuple),這就是包裹位置傳遞。
為了提醒python引數,name是包裹位置傳遞所用的元組名,在定義func時,在name前加*號。
下面是包裹關鍵字傳遞的例子:
def func(**dict):
print type(dict)
print dict
func(a=1,b=9)
func(m=2,n=1,c=11)
與上面乙個例子類似,dict是乙個字典,收集所有的關鍵字,傳遞給函式func。為了提醒python,引數dict是包裹關鍵字傳遞所用的字典,在dict前加**。
包裹傳遞的關鍵在於定義函式時,在相應元組或字典前加*或**。
解包裹和*,也可以在呼叫的時候使用,即解包裹(unpacking), 下面為例:
def func(a,b,c):
print a,b,c
args = (1,3,4)
func(*args)
在這個例子中,所謂的解包裹,就是在傳遞tuple時,讓tuple的每乙個元素對應乙個位置引數。在呼叫func時使用*,是為了提醒python:我想要把args拆成分散的三個元素,分別傳遞給a,b,c。(設想一下在呼叫func時,args前面沒有*會是什麼後果?)
相應的,也存在對詞典的解包裹,使用相同的func定義,然後:
dict =
func(**dict)
在傳遞詞典dict時,讓詞典的每個鍵值對作為乙個關鍵字傳遞給func。
混合在定義或者呼叫引數時,引數的幾種傳遞方式可以混合。但在過程中要小心前後順序。基本原則是,先位置,再關鍵字,再包裹位置,再包裹關鍵字,並且根據上面所說的原理細細分辨。
注意:請注意定義時和呼叫時的區分。包裹和解包裹並不是相反操作,是兩個相對獨立的過程。
python學習之傳遞函式
在python中,函式也是物件。所以函式是可以被引用的,也可以作為引數傳入函式 想想裝飾器 話不多說,上例子。例子 於 python核心程式設計第二版 例1.使用別名呼叫 def foo print in foo bar foo 對函式物件新建乙個引用 bar in foo 在上述 中,把foo賦值...
如何傳遞函式
摘自 非同步 庫提供了一些函式,這些函式使您可以在元件之間傳遞訊息。這些訊息傳遞函式與各種訊息塊型別一起使用。有關併發執行時所定義的訊息塊型別的更多資訊,請參見非同步訊息塊。各節內容 本主題描述以下訊息傳遞函式 send 和 asend concurrency send 函式一條訊息傳送到指定目標同...
c 傳遞函式引數
傳遞普通函式和類的成員函式方式不同,原因是傳遞函式引數實際傳的是函式的位址,但是普通函式和成員函式的位址獲取方式不太相同。普通函式只要傳遞乙個函式名稱即可,但是成員函式在類的內部中沒有位址,選擇乙個成員函式就意味著得知道該函式在類中的偏移量,因此需要知道該物件和對應的偏移量,才能得到真實的位址。當然...