python函數(shù)綁定值 python 函數(shù)幫助

python中視圖函數(shù)傳值的數(shù)據(jù)類型可以傳對(duì)象嗎

python的一切數(shù)據(jù)類型都是對(duì)象。但是python的對(duì)象分為不可變對(duì)象和可變對(duì)象。python的變量是引用,對(duì)python變量的賦值是引用去綁定該對(duì)象。

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),洛隆企業(yè)網(wǎng)站建設(shè),洛隆品牌網(wǎng)站建設(shè),網(wǎng)站定制,洛隆網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,洛隆網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

可變對(duì)象的數(shù)據(jù)發(fā)生改變,例如列表和字典,引用不會(huì)更改綁定對(duì)象,畢竟本身就是用于增刪改查的,頻繁地產(chǎn)生新對(duì)象必然導(dǎo)致開銷巨大,只需要該對(duì)象內(nèi)部變化就行;但對(duì)于綁定了不可變對(duì)象的引用,對(duì)象一旦改變就會(huì)使引用綁定新的對(duì)象。

這一點(diǎn)也會(huì)反應(yīng)到函數(shù)的參數(shù)上。python的傳值方式是“傳對(duì)象”引用。python的函數(shù),形參實(shí)際上是引用,實(shí)參便是對(duì)象綁定到該引用上。本質(zhì)是形參會(huì)被作為函數(shù)的局部變量,在開辟的函數(shù)的棧內(nèi)存中被聲明。

簡(jiǎn)要來講:

如果參數(shù)是數(shù),則類似值傳遞,

如果參數(shù)是列表和字典,則類似引用傳遞。

每個(gè)對(duì)象都會(huì)有個(gè)id, 可以用id()驗(yàn)證以上說法:

這個(gè)函數(shù)的參數(shù)是列表,是可變對(duì)象。

求幫助,Python閉包和返回函數(shù)問題

(1)unpack tuple和list, 可以讓函數(shù)返回多個(gè)值

def count():

return (1, 2, 3) # 或者 return [1, 2, 3]

# 把列表解包,把1 2 3 分別賦值給 a b c

a, b, c = count()

print a, b, c

# 輸出 1, 2, 3

(2)假設(shè)你知道Python的dict類型。Python中,在函數(shù)中定義一個(gè)變量的時(shí)候,會(huì)在一個(gè)隱藏的叫l(wèi)ocals的dict里面插入key-value,其中key是變量名,value是變量值。而引用一個(gè)變量的時(shí)候,則首先會(huì)在這個(gè)叫l(wèi)ocals的dict里面,根據(jù)變量名作為key,去查對(duì)應(yīng)的值。

var = 1 # 你可以認(rèn)為這里進(jìn)行了 locals['var'] = 1 的操作

print var # 在對(duì)var變量進(jìn)行求值的時(shí)候,就在locals['var']里面找var變量對(duì)應(yīng)的值

(3)for循環(huán)中,每次循環(huán)只是給 `i` 重新綁定值

for i in (1, 2, 3):

print i

print i

# 一次輸入 1 2 3 3

每次`for i in (1, 2, 3)`相當(dāng)于在`print i`之前,進(jìn)行了

`locals['i'] = 1`

`locals['i'] = 2`

`locals['i'] = 3`

的操作

所以最后的`print i`再去locals字典里面找`i`的時(shí)候,就變成 3 了。

(4)閉包是 一個(gè)函數(shù)加上這個(gè)函數(shù)引用的外部變量

var = 1

def f():

print var

# 這里的閉包是函數(shù) f 和 f 引用的外部變量 var

def count():

var2 = 2

def f():

print var2

# 這里的閉包是函數(shù) f 和 f 引用的外部變量 var2

return f

拿第一個(gè)函數(shù) f 來說。在 f 運(yùn)行的時(shí)候,解釋器拿著'var'這個(gè)字符串去locals字典里面找,發(fā)現(xiàn)找不到,于是在closure字典里面找,最后closure字典里面找,你可以認(rèn)為就是找closure['var'],然后發(fā)現(xiàn)找到對(duì)應(yīng)的值。count里面的 f 函數(shù)同理。

(為了容易理解,我這里說謊了。實(shí)際上 f 壓根沒有closure,count里面的 f 才有。其實(shí)closure壓根不是像locals那樣的字典)

(5)函數(shù)定義時(shí),函數(shù)只是記錄變量的名字。

要區(qū)分什么是名字,什么是值。

`i = 1`這里 i 只是名字,只是一個(gè)字符串 'i' 。這句話運(yùn)行完,locals['i'] = 1,就說 i 對(duì)應(yīng)的值是1

def count():

fs = []

for i in range(1, 4):

# 定義一個(gè)函數(shù),等價(jià)于運(yùn)行了 locals['f'] = 真正生成的函數(shù)

# 每次循環(huán),這里都會(huì)重新生成一個(gè)函數(shù),然后把重新生成的函數(shù)賦值給 locals['f']

def f():

return i * i # 引用了'i'這個(gè)名字,但并不是引用了'i'對(duì)應(yīng)的值

# 等價(jià)于 locals['fs'].append(locals['f'])

# f 不是函數(shù),它只是一個(gè)名字'f'。f 引用的東西,也就是locals['f']才是真正的函數(shù)

fs.append(f)

# 于是這個(gè)for循環(huán)生成了三個(gè)函數(shù),這三個(gè)函數(shù)是沒有名字的,這個(gè)函數(shù)運(yùn)行完后,它們跟'f'這個(gè)名字就毛關(guān)系都沒有了(是的我說慌了,但可以先不管)

# 把整個(gè)列表返回,這個(gè)列表包含了三個(gè)函數(shù)

return fs

# count()返回三個(gè)函數(shù)的列表,unpack 列表的語法把列表中的三個(gè)函數(shù)抽出來,重新給他們命名為 f1, f2, f3

# 也就是說,

# locals['f1'] = 列表中的第1個(gè)函數(shù)

# locals['f2'] = 列表中的第2個(gè)函數(shù)

# locals['f3'] = 列表中的第3個(gè)函數(shù)

# 這三個(gè)函數(shù)跟'f'這個(gè)名字現(xiàn)在毛關(guān)系都沒有。(其實(shí)是有的,但為了說明需要簡(jiǎn)化,現(xiàn)在你可以完全不管括號(hào)里面說的話)

f1, f2, f3 = count()

print f1(), f2(), f3()

# 好了我們運(yùn)行它們,輸入都是 9

# def f():

# return i * i

這是因?yàn)?f1 現(xiàn)在對(duì)應(yīng)的函數(shù),里面引用了 'i' 這個(gè)字符串,我們根據(jù) 'i '這個(gè)字符串去找它對(duì)應(yīng)的值,先找到 f 當(dāng)前的locals字典,發(fā)現(xiàn)沒有,因?yàn)楹瘮?shù)定義的時(shí)候沒有定義 i 變量。然后再去closure['i']里面找,因?yàn)镻ython是通過closure字典實(shí)現(xiàn)閉包的(就當(dāng)它是對(duì)的好不好),所以我們可以在closure['i']找到值,這個(gè)值就是我們上一次運(yùn)行的時(shí)候count函數(shù)里面殘留的locals['i'],而由于for循環(huán)三遍之后,locals['i'] == 3,所以找到 i 的值就是3。所以最后輸出都是9

Python-嵌套函數(shù)中的局部變量?

嵌套函數(shù)在執(zhí)行時(shí)(而不是在定義時(shí))從父范圍中查找變量。

編譯函數(shù)主體,然后驗(yàn)證“自由”變量(未在函數(shù)本身中通過賦值定義),然后將其作為閉包單元綁定到函數(shù),并且代碼使用索引引用每個(gè)單元格。pet_function因此具有一個(gè)自由變量(cage),然后將其通過一個(gè)閉合單元引用,索引為0的閉合本身指向局部變量cage在get_petters功能。

當(dāng)你實(shí)際調(diào)用該函數(shù)時(shí),該閉包將用于在你調(diào)用該函數(shù)時(shí)查看cage周圍作用域中的值。問題就在這里。在你調(diào)用函數(shù)時(shí),該函數(shù)已經(jīng)完成了對(duì)其結(jié)果的計(jì)算。將在在執(zhí)行過程中的一些點(diǎn)局部變量分配各的,和字符串,但在功能的結(jié)束,包含了最后一個(gè)值。因此,當(dāng)你調(diào)用每個(gè)動(dòng)態(tài)返回的函數(shù)時(shí),就會(huì)得到打印的值。get_petterscage'cow''dog''cat'cage'cat''cat'

解決方法是不依賴閉包。你可以改用部分函數(shù),創(chuàng)建新的函數(shù)作用域或?qū)⒆兞拷壎殛P(guān)鍵字parameter的默認(rèn)值。

部分函數(shù)示例,使用functools.partial():

from functools import partialdef pet_function(cage=None):

print "Mary pets the " + cage.animal + "."yield (animal, partial(gotimes, partial(pet_function, cage=cage)))

創(chuàng)建一個(gè)新的范圍示例:

def scoped_cage(cage=None):

def pet_function():

print "Mary pets the " + cage.animal + "."

return pet_functionyield (animal, partial(gotimes, scoped_cage(cage)))

將變量綁定為關(guān)鍵字參數(shù)的默認(rèn)值:

def pet_function(cage=cage):

print "Mary pets the " + cage.animal + "."yield (animal, partial(gotimes, pet_function))

無需scoped_cage在循環(huán)中定義函數(shù),編譯僅進(jìn)行一次,而不是在循環(huán)的每次迭代中進(jìn)行。

python中關(guān)于bind()的使用

讓前面那個(gè)事件去觸發(fā)后面的事件不就成了。調(diào) 用后面那個(gè)函數(shù)。 所以不需要一個(gè)事件下bind很多個(gè)函數(shù)。只需要一個(gè)母函數(shù),調(diào) 用一組子函數(shù)。

分享名稱:python函數(shù)綁定值 python 函數(shù)幫助
標(biāo)題網(wǎng)址:http://muchs.cn/article40/dopooeo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)品牌網(wǎng)站制作、網(wǎng)站策劃、企業(yè)網(wǎng)站制作、網(wǎng)站營銷網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)