函數(shù)
isinstance(x, int)
:檢查參數(shù)類型
callable(object)
:檢查一個(gè)對(duì)象是否是可調(diào)用的。函數(shù)只磷、方法阐斜、lambda 函式、 類以及實(shí)現(xiàn)了 call 方法的類實(shí)例, 它都返回 True
>>> callable(0)
false
def func():
pass
>>> callable(func)
true
1.可變參數(shù):numbers
`在參數(shù)前加個(gè)*號(hào)表示把numbers的所有元素作為可變參數(shù)傳進(jìn)函數(shù)內(nèi)部续捂。
在函數(shù)內(nèi)部,參數(shù)numbers接收到的是一個(gè)`tuple``
def function(*numbers):
pass
2.關(guān)鍵字參數(shù):kw
`關(guān)鍵字參數(shù)允許你傳入0個(gè)或任意個(gè)含參數(shù)名的參數(shù)宦搬,
關(guān)鍵字參數(shù)在函數(shù)內(nèi)部自動(dòng)組裝為一個(gè)`dict``
def person(name, age, **kw):
print('name:', name, 'age:', age, 'other:', kw)
>> person('Bob', 35, city='Beijing')
name: Bob age: 35 other: {'city': 'Beijing'}
>>> extra = {'city': 'Beijing', 'job': 'Engineer'}
>>> person('Jack', 24, **extra)
name: Jack age: 24 other: {'city': 'Beijing', 'job': 'Engineer'}
3.命名關(guān)鍵字參數(shù):
`命名關(guān)鍵字參數(shù)需要一個(gè)特殊分隔符*牙瓢,`*`后面的參數(shù)被視為命名關(guān)鍵字參數(shù).
命名關(guān)鍵字參數(shù)必須傳入?yún)?shù)名,可以理解為是參數(shù)前加了個(gè)描述`
def person(name, age, *, city, job):
print(name, age, city, job)
>>> person('Jack', 24, city='Beijing', job='Engineer')
Jack 24 Beijing Engineer
參數(shù)定義的順序必須是:
必選參數(shù)、默認(rèn)參數(shù)间校、可變參數(shù)矾克、命名關(guān)鍵字參數(shù)和關(guān)鍵字參數(shù)
遞歸:如果一個(gè)函數(shù)在內(nèi)部調(diào)用自身本身,這個(gè)函數(shù)就是遞歸函數(shù)憔足。
舉例:fact(n) = n! = 1 x 2 x 3 x ... x (n-1) x n = (n-1)! x n = fact(n-1) x n
fact(n)用遞歸的方式寫出來就是:
`這里需要注意的是`:遞歸函數(shù)需要注意防止棧溢出胁附。在計(jì)算機(jī)中,函數(shù)調(diào)用是通過棧(stack)這種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)的滓彰,
每當(dāng)進(jìn)入一個(gè)函數(shù)調(diào)用控妻,棧就會(huì)加一層棧幀,每當(dāng)函數(shù)返回揭绑,棧就會(huì)減一層棧幀弓候。
由于棧的大小不是無限的,所以他匪,遞歸調(diào)用的次數(shù)過多菇存,會(huì)導(dǎo)致棧溢出。fact(1000):就會(huì)棧溢出邦蜜。所以這種方法不太好撰筷。
def fact(n):
if n==1:
return 1
return n * fact(n - 1)
`解決遞歸調(diào)用棧溢出的方法是通過尾遞歸優(yōu)化`:尾遞歸是指,在函數(shù)返回的時(shí)候畦徘,調(diào)用自身本身毕籽,并且,return語句不能包含表達(dá)式井辆。
這樣关筒,編譯器或者解釋器就可以把尾遞歸做優(yōu)化,使遞歸本身無論調(diào)用多少次杯缺,都只占用一個(gè)棧幀蒸播,不會(huì)出現(xiàn)棧溢出的情況。
def fact(n):
return fact_iter(n, 1)
def fact_iter(num, product):
if num == 1:
return product
return fact_iter(num - 1, num * product)