例子需要包含頭文件 #include

  bind1st和bind2nd函數用於將一個二元算子(binary functor,bf)轉換成一元算子(unary functor,uf)。爲了達到這個目的,它們需要兩個參數:要轉換的bf和一個值(v)。

 

         可能這麼解釋以後大家還不是很清楚,那麼就說點白話吧。我們在做比較的時候所寫的表達式像 x > k ,x < k,這裏的k是一個參數表示你程序裏面的表達式要和k值去比較。上面這兩個表達式對應的應該是bind2nd ,簡單的理解就是把k作爲比較表達式的第二個參數。如果使用bind1st則對應的表達式是 k > x,k < x,也就是把k作爲比較表達式的第一個參數。大家可能會注意到這裏面沒有=的比較,先彆着急,後面將會說道如何實現=的比較。先舉兩個例子看看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());

這裏的比較表達式相當於arr.value < 100

如果用bind1st則表達的意思就恰恰相反

// 移除所有大於100的元素
arr.erase( std::remove_if( arr.begin(),  arr.end(),
    std::bind1st( std::less< int>(), 100)), arr.end());

這裏的表達式相當於100 < arr.value

當然爲了實現刪除大於100的元素你同樣可以使用bind2nd

// 移除所有大於100的元素
arr.erase( std::remove_if( arr.begin(),  arr.end(),
    std::bind2nd( std::greater< int>(), 100)), arr.end());

前面說道=的比較,比如說x <= k怎麼實現呢,std又提供了一個好東西not1,我們可以說 !(x > k) 和 x <= k是等價的,那麼我們看看下面的表達式:

// 移除所有小於等於100的元素
arr.erase( std::remove_if( arr.begin(),  arr.end(),
    std::not1(std::bind2nd( std::greater< int>(), 100))), arr.end());

說明:not1是否定返回值是單目的函數,std中還有not2它是否定返回值是雙目的函數

//頭文件

#include <algorithm>

#include <functional>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章