以下轉載,尚未確認內容正確。有些代碼中空格有問題,需全部重寫。
return 語句就是將結果返回到調用的地方,並把程序的控制權一起返回。
程序運行到所遇到的第一個return即返回(退出def塊),不會再運行第二個return,要返回兩個數值,寫成一行即可:
def a(x, y):
if x == y:
return x
return y #不起作用
print(a(3, 3))
'''輸出結果:
3
'''
def a(x, y):
if x == y:
return x, y
print(a(3, 3))
'''輸出結果:
(3, 3)
'''
但是也並不意味着一個函數體中只能有一個return 語句,例如:
def test_return(x):
if x > 0:
return x
else:
return 0
print(test_return(-1))
print(test_return(0))
print(test_return(5))
'''輸出結果:
0
0
5
'''
函數沒有 return,默認 return 一個 None 對象。
遞歸函數中沒有return 的情況:
def gcd(a,b):
if a%b==0:
return b
else:
gcd(b,a%b)
分析:else 中沒有 return 就沒有出口,這個程序是自己內部運行,程序沒有返回值,
return 和 print 的區別:
x = 1
y = 2
def add (x, y):
z = x + y
return z
print (add(x,y)
x = 1
y = 2
def add (x, y):
z = x + y
print z
print (add(x,y))
在交互模式下,return的結果會自動打印出來,而作爲腳本單獨運行時則需要print函數才能顯示。
默認情況下,遇見 return 函數就會返回給調用者,但是 try,finally情況除外:
def func():
try:
print 98
return 'ok' #函數得到了一個返回值
finally: #finally語句塊中的語句依然會執行
print 98
print fun()
複製代碼
輸出:
98
98
ok
函數作爲返回值返回:
def lazy_sum(*args):
def sum():
x=0
for n in args:
x=x+n
return x
return sum
lazy_sum(1,2,3,4,5,6,7,8,9) #這時候lazy_sum 並沒有執行,而是返回一個指向求和的函數的函數名sum 的內存地址。
f=lazy_sum(1,2,3,4,5,6,7,8,9)
print(type(f))
print(f()) # 調用f()函數,才真正調用了 sum 函數進行求和,
這其實就是閉包。
返回一個函數列表:
def count():
fs = []
for i in range(1,4):
def f():
return i*i
fs.append(f)
return fs
f1, f2, f3 = count()
print(f1())
print(f2())
print(f3())
輸出:
9
9
9
執行過程:
當i=1, 執行for循環, 結果返回函數f的函數地址,存在列表fs中的第一個位置上。
當i=2, 由於fs列表中第一個元素所指的函數中的i是count函數的局部變量,i也指向了2;然後執行for循環, 結果返回函數f的函數地址,存在列表fs中的第二個位置上。
當i=3, 同理,在fs列表第一個和第二個元素所指的函數中的i變量指向了3; 然後執行for循環, 結果返回函數f的函數地址,存在列表fs中的第三個位置上。
所以在調用f1()的時候,函數中的i是指向3的:
f1():
return 3*3
同理f2(), f3()結果都爲9
閉包時牢記的一點就是:返回函數不要引用任何循環變量,或者後續會發生變化的變量。即包在裏面的函數(本例爲f()),不要引用外部函數(本例爲count())的任何循環變量如果一定要引入循環變量,方法是再創建一個函數,用該函數的參數綁定循環變量當前的值,無論該循環變量後續如何更改,已綁定到函數參數的值不變:
def count():
fs=[]
for i in range(1,4):
def f(j):
def g():
return j*j
return g
fs.append(f(i))
return fs
f1,f2,f3=count()
print(f1())
print(f2())
print(f3())