Python對指針做了良好封裝,一切都是“對象”,一切對象都有一個“變量”指向它。這個“變量”就是“指針”。和Java一樣,它不可以隨機(jī)移動,不可以運(yùn)算。包括函數(shù)也是一個“對象”,用一個變量指向它,就是指向函數(shù)的入口地址。
C++中指向函數(shù)入口地址的指針,叫做函數(shù)指針。所以,這一名詞我們也借用到Python中。
比如,我寫一個排序的代碼段,用STL里的sort:
intarr[10]={5,8,4,7,6,5,7,4,2,9};
std::sort(arr,arr+10);
默認(rèn)是升序排序。如果我想要特殊的排序標(biāo)準(zhǔn),那就要提供第三個參數(shù)。第三個參數(shù)就是一個函數(shù)指針。sort的原則就是,假設(shè)原序列中b在a之前,當(dāng)函數(shù)指針pf(a,b)調(diào)用的函數(shù)的返回值為true時(shí)發(fā)生交換。返回false時(shí),和排序的算法有關(guān),比如sort是不穩(wěn)定排序,所以兩數(shù)相等時(shí)仍有可能交換位置。
我們寫一個降序排序。那就需要先寫一個比較函數(shù)cmp:
boolcmp(inta,intb)
{
returna>b;//當(dāng)后面的數(shù)大于前面時(shí)交換
}
然后,函數(shù)名就是它的入口地址,所以我們把它傳進(jìn)去:
std::sort(a,a+10,cmp);
Python中也類似,假設(shè)有一個列表的排序函數(shù)Sort(list,cmp)
那么,cmp也是一個“對象”,它可以傳入函數(shù)入口地址。調(diào)用語句如下:
defcmp(a,b):returna>b
li=[5,8,4,7,6,5,7,4,2,9]
Sort(li,cmp)
也就類似于函數(shù)指針的功能。
以上內(nèi)容為大家介紹了Python培訓(xùn)之python中有指針嗎,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。