国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python中設置變量作為默認值時容易遇到的錯誤

2019-11-25 17:51:29
字體:
來源:轉載
供稿:網友

思考一下下面的代碼片段:
 

def foo(numbers=[]):  numbers.append(9)  print numbers

在這里,我們定義了一個 list (默認為空),給它加入9并且打印出來。
 

>>> foo()[9]>>> foo(numbers=[1,2])[1, 2, 9]>>> foo(numbers=[1,2,3])[1, 2, 3, 9]

看起來還行吧?可是當我們不輸入number 參數來調用 foo 函數時,神奇的事情發生了:
 

>>> foo() # first time, like before[9]>>> foo() # second time[9, 9]>>> foo() # third time...[9, 9, 9]>>> foo() # WHAT IS THIS BLACK MAGIC?![9, 9, 9, 9]

那么,這是神馬情況?直覺告訴我們無論我們不輸入 number 參數調用 foo 函數多少次,這里的9應該被分配進了一個空的 list。這是錯的!在Python里,函數的默認值實在函數定義的時候實例化的,而不是在調用的時候。

那么我們仍然會問,為什么在調用函數的時候這個默認值卻被賦予了不同的值?因為在你每次給函數指定一個默認值的時候,Python都會存儲這個值。如果在調用函數的時候重寫了默認值,那么這個存儲的值就不會被使用。當你不重寫默認值的時候,那么Python就會讓默認值引用存儲的值(這個例子里的numbers)。它并不是將存儲的值拷貝來為這個變量賦值。這個概念可能對初學者來說,理解起來會比較吃力,所以可以這樣來理解:有兩個變量,一個是內部的,一個是當前運行時的變量?,F實就是我們有兩個變量來用相同的值進行交互,所以一旦 numbers 的值發生變化,也會改變Python里面保存的初始值的記錄。

那么解決方案如下:
 

def foo(numbers=None):  if numbers is None:    numbers = []  numbers.append(9)  print numbers

通常,當人們聽到這里,大家會問另一個關于默認值的問題。思考下面的程序:
 

def foo(count=0):  count += 1  print count

當我們運行它的時候,其結果完全是我們期望的:
 

>>> foo()1>>> foo()1>>> foo(2)3>>> foo(3)4>>> foo()1

這又是為啥呢?其秘密不在與默認值被賦值的時候,而是這個默認值本身。整型是一種不可變的變量。跟 list 類型不同,在函數執行的過程中,整型變量是不能被改變的。當我們執行 count+=1 這句話時,我們并沒有改變 count 這個變量原有的值。而是讓 count 指向了不同的值??墒?,當我們執行 numbers.append(9) 的時候,我們改變了原有的 list 。因而導致了這種結果。

下面是在函數里使用默認值時會碰到的另一種相同問題:
 

def print_now(now=time.time()):  print now

跟前面一樣,time.time() 的值是可變的,那么它只會在函數定義的時候計算,所以無論調用多少次,都會返回相同的時間 ― 這里輸出的時間是程序被Python解釋運行的時間。

>>> print_now()1373121487.91>>> print_now()1373121487.91>>> print_now()1373121487.91

* 這個問題和它的解決方案在 Python 2.x 和 3.x 里都是類似的,在Python 3.x 里面唯一的不同,是里面的print 表達式應該是函數調用的方式(print(numbers))。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湖南省| 建宁县| 新安县| 石屏县| 瓦房店市| 泽州县| 双桥区| 平乡县| 广饶县| 伊通| 三门县| 自贡市| 上林县| 汕头市| 油尖旺区| 太白县| 雷山县| 仙桃市| 姜堰市| 竹北市| 镇坪县| 佛冈县| 舒兰市| 安宁市| 松桃| 定南县| 崇信县| 绍兴市| 永胜县| 临洮县| 凤庆县| 铁岭县| 肃北| 尼勒克县| 高雄市| 鄢陵县| 响水县| 永善县| 肃宁县| 北流市| 万荣县|