在python中l(wèi)ist作函數(shù)形參,防止被實(shí)參修改的實(shí)現(xiàn)方法
0.摘要
我們將一個(gè)list傳入函數(shù)后,函數(shù)內(nèi)部對(duì)實(shí)參修改后,形參也會(huì)隨之改變。本文將主要介紹這種錯(cuò)誤的現(xiàn)象、原因和解決方法。
1.代碼示例
def fun(inner_lst): inner_lst.pop() lst = [1,2,3,4,5,6,7]fun(lst)print(lst)fun(lst)print(lst)fun(lst)print(lst)fun(lst)print(lst)fun(lst)print(lst)
從運(yùn)行結(jié)果上,可以看出,
雖然我們改變的是fun()內(nèi)部的inner_lst,但是,外部的lst也隨之改變了。
因此,如果我們將一個(gè)列表傳入一個(gè)函數(shù)的,運(yùn)行這個(gè)函數(shù),可能會(huì)破壞我們的原始數(shù)據(jù),這可能并不是我們想要看到的。
2.原因
首先,我們解釋一下上面這種情況的原因。
在python中,數(shù)據(jù)有兩種類型:mutable(可變) 和 immutable (不可變)
list ,dict是mutable的;
int , string , float ,tuple是inmutable 的。
在函數(shù)參數(shù)的傳遞過程中:
對(duì)于inmutable object ,函數(shù)參數(shù)傳遞是值
對(duì)于mutable object,函數(shù)參數(shù)傳遞是指針
因此,當(dāng)我們把lst傳入fun()函數(shù)時(shí),實(shí)際是把lst的指針傳遞給了inner_lst變量。
所以,lst的值會(huì)隨著inner_lst進(jìn)行變化。
3.解決
如果我們傳入函數(shù)的形參是一個(gè)list變量,那么我們需要先拷貝一份,之后的操作在備份上進(jìn)行,這樣便不會(huì)破壞原始數(shù)據(jù)。
比如:
def fun(inner_lst): lst_copy = inner_lst.copy() lst_copy.pop() print('lst_copy = ',lst_copy)lst = [1,2,3,4,5,6,7]fun(lst)print('lst = ',lst)
補(bǔ)充知識(shí):Python 函數(shù)參數(shù)List 形參改變實(shí)參問題
在學(xué)習(xí)Python 中的排序中,發(fā)現(xiàn)一個(gè)問題,寫的排序函數(shù)會(huì)改變實(shí)參中的原List,不方便,我做對(duì)比,經(jīng)過查詢和學(xué)習(xí),總結(jié)如下:
List 改變某一項(xiàng)值,會(huì)改變實(shí)參。
整體從新賦值,不會(huì)改變實(shí)參。
原因?yàn)樾螀⒑蛯?shí)參這兩個(gè)標(biāo)簽指向的都是同樣的一塊列表。改變其中一個(gè)另一個(gè)也就跟著改變了。
解決方法如下可在參數(shù)中加:
在函數(shù)中復(fù)制一個(gè)List,在新的List中進(jìn)行排序。
def selectionSort(xx): x=xx[:] i = 0 while i < len(x) - 1: j = i + 1 minindex = i while j < len(x): if x[minindex] > x[j]:minindex = j j += 1 x[minindex], x[i] = x[i], x[minindex] i += 1 return x
以上這篇在python中l(wèi)ist作函數(shù)形參,防止被實(shí)參修改的實(shí)現(xiàn)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
