以前在使用stl的過(guò)程中發(fā)現(xiàn)bind1st和bind2nd這兩個(gè)函數(shù),當(dāng)時(shí)不太理解什么意思,今天在網(wǎng)上查了一下相關(guān)資料發(fā)現(xiàn)竟然很簡(jiǎn)單,下面我就具體解釋一下他們的用法。
bind1st和bind2nd函數(shù)用于將一個(gè)二元算子(binary functor,bf)轉(zhuǎn)換成一元算子(unary functor,uf)。為了達(dá)到這個(gè)目的,它們需要兩個(gè)參數(shù):要轉(zhuǎn)換的bf和一個(gè)值(v)。
可能這么解釋以后大家還不是很清楚,那么就說(shuō)點(diǎn)白話吧。我們?cè)谧霰容^的時(shí)候所寫(xiě)的表達(dá)式像 x > k ,x < k,這里的k是一個(gè)參數(shù)表示你程序里面的表達(dá)式要和k值去比較。上面這兩個(gè)表達(dá)式對(duì)應(yīng)的應(yīng)該是bind2nd ,簡(jiǎn)單的理解就是把k作為比較表達(dá)式的第二個(gè)參數(shù)。如果使用bind1st則對(duì)應(yīng)的表達(dá)式是 k > x,k < x,也就是把k作為比較表達(dá)式的第一個(gè)參數(shù)。大家可能會(huì)注意到這里面沒(méi)有=的比較,先別著急,后面將會(huì)說(shuō)道如何實(shí)現(xiàn)=的比較。先舉兩個(gè)例子看看 bind1st和bind2nd的用法。
int a[] = {1, 2, 100, 200};
std::vector< int> arr(a, a + 4);
// 移除所有小于100的元素
arr.erase( std::remove_if( arr.begin(), arr.end(),
std::bind2nd( std::less< int>(), 100)), arr.end());
這里的比較表達(dá)式相當(dāng)于arr.value < 100
如果用bind1st則表達(dá)的意思就恰恰相反
// 移除所有大于100的元素
arr.erase( std::remove_if( arr.begin(), arr.end(),
std::bind1st( std::less< int>(), 100)), arr.end());
這里的表達(dá)式相當(dāng)于100 < arr.value
當(dāng)然為了實(shí)現(xiàn)刪除大于100的元素你同樣可以使用bind2nd
// 移除所有大于100的元素
arr.erase( std::remove_if( arr.begin(), arr.end(),
std::bind2nd( std::greater< int>(), 100)), arr.end());
前面說(shuō)道=的比較,比如說(shuō)x <= k怎么實(shí)現(xiàn)呢,std又提供了一個(gè)好東西not1,我們可以說(shuō) !(x > k) 和 x <= k是等價(jià)的,那么我們看看下面的表達(dá)式:
// 移除所有小于等于100的元素
arr.erase( std::remove_if( arr.begin(), arr.end(),
std::not1(std::bind2nd( std::greater< int>(), 100))), arr.end());
說(shuō)明:not1是否定返回值是單目的函數(shù),std中還有not2它是否定返回值是雙目的函數(shù)
例子需要包含頭文件
#include <vector>
#include <algorithm>
#include <functional>