欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c/c++ 標準庫 bind 函數(shù)詳解

 更新時間:2018年09月20日 09:20:36   作者:小石王  
bind是一組用于函數(shù)綁定的模板。在對某個函數(shù)進行綁定時,可以指定部分參數(shù)或全部參數(shù),也可以不指定任何參數(shù),還可以調(diào)整各個參數(shù)間的順序。這篇文章主要介紹了c/c++ 標準庫 bind 函數(shù) ,需要的朋友可以參考下

bind函數(shù)定義在頭文件 functional 中??梢詫?bind 函數(shù)看作一個通用的函數(shù)適配器,它接受一個可調(diào)用對象,生成一個新的可調(diào)用對象來“適應(yīng)”原對象的參數(shù)列表。

bind函數(shù):接收一個函數(shù)名作為參數(shù),生成一個新的函數(shù)。

auto newCallable = bind(callbale, arg_list);

arg_list中的參數(shù)可能包含入_1, _2等,這些是新函數(shù)newCallable的參數(shù)。

在這篇博客lambda 表達式 介紹 中,討論了find_if的第三個參數(shù)的問題,當時是用lambda表達式解決的,有了bind函數(shù)后,也可以用bind函數(shù)解決。

解決辦法:bind(check_size, _1, sz)

auto idx = find_if(svec.begin(),svec.end(),bind(check_size, _1, 6));

其實,newCall= bind(check_size, _1, sz)返回了一個新的函數(shù)newCall ,這個newCall 只接受一個參數(shù),正好滿足find_if的要求。

•從find_if的角度來看,啊,newCall是含有一個參數(shù)的函數(shù),OK,沒問題。
•從程序猿的角度看,check_size是含有2個參數(shù)的函數(shù),只是提前把sz(6)綁定到了newCall上了,
•當調(diào)用newCall(s),實際是調(diào)用了check_size(s, 6),相當于newCall也有2個參數(shù),只是第二個參數(shù)有個默認值為6。newCall(const string &s, size_t sz = 6); ,所以調(diào)用newCall時,傳遞一個參數(shù)就夠了。

注意:_1,_2等,是放在了命名空間placeholder中,所以要使用:

//_1,_n定在std::placeholders里面
using namespace std::placeholders;

bind參數(shù)用法:

//g是以個有2個參數(shù)的可調(diào)用對象
auto g = bind(func, a, b, _2, c, _1);//func是有5個參數(shù)的函數(shù)

調(diào)用g(X, Y), 等于 func(a, b, Y, c, X)

例子:

#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <functional>
using namespace std;
//_1,_n定在std::placeholders里面                        
using namespace std::placeholders;
bool check_size(const string &s, string::size_type sz){
 return s.size() >= sz;
}
bool shorter(const string &a, const string &b){
 return a.size() < b.size();
}
ostream& print(ostream& os, const string &s, const char &c){
 //c = ',';                                  
 return os << s << c;
}
int main(){
 /*                                      
 //用bind實現(xiàn)了和lambda一樣的功能                       
 vector<string> svec{"aab","d","aa","bb","e","bbb"};              
 stable_sort(svec.begin(),svec.end(),[](const string &a, const string &b){   
   return a.size() < b.size();                        
  });                                     
 string::size_type sz = 3;                           
 auto idx = find_if(svec.begin(),svec.end(),bind(check_size, _1, sz));     
 cout << *idx << endl;                             
 idx = find_if(svec.begin(),svec.end(),[sz](const string &s){         
   return s.size() >= sz;                          
  });                                     
 cout << *idx << endl;                             
 */
 /*                                      
 //用bind改變原來函數(shù)的參數(shù)的位置                       
 //升序                                    
 vector<string> svec{"aab","d","aa","bb","e","bbb"};              
 sort(svec.begin(), svec.end(), shorter);                   
 for(auto const &s : svec){                          
  cout << s << " ";                              
 }                                       
 cout << endl;                                 
 //由于調(diào)換了shorter參數(shù)的位置,所以變成了降序                 
 sort(svec.begin(), svec.end(),bind(shorter, _2, _1));             
 for(auto const &s : svec){                          
  cout << s << " ";                              
 }                                       
 cout << endl;                                 
 */
 //bind引用,必須使用ref或者cref函數(shù),把對象轉(zhuǎn)化成引用,不能用&         
 ostream &os = cout;
 const char c = ' ';
 vector<string> svec{"aab","d","aa","bb","e","bbb"};
 for_each(svec.begin(),svec.end(),[&os, c](const string &s){
   os << s << c;
  });
 os << endl;
 for_each(svec.begin(),svec.end(),bind(print, ref(os), _1, cref(c)));
 os << endl;
 cout << c << endl;
}

總結(jié)

以上所述是小編給大家介紹的c/c++ 標準庫 bind 函數(shù)詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • C++17之std::any的具體使用

    C++17之std::any的具體使用

    本文主要介紹了C++17之std::any的具體使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++求最大公約數(shù)四種方法解析

    C++求最大公約數(shù)四種方法解析

    這篇文章主要為大家詳細介紹了C++求最大公約數(shù)四種方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • C/C++淺析鄰接表拓撲排序算法的實現(xiàn)

    C/C++淺析鄰接表拓撲排序算法的實現(xiàn)

    這篇文章主要介紹了C/C++對于鄰接表拓撲排序算法的實現(xiàn),鄰接表是圖的一種鏈式存儲方法,其數(shù)據(jù)結(jié)構(gòu)包括兩部分:節(jié)點和鄰接點
    2022-07-07
  • C語言中的字符(char)詳細講解

    C語言中的字符(char)詳細講解

    本篇文章主要介紹C語言中char的知識,并附有代碼實例,以便大家在學習的時候更好的理解,有需要的可以看一下
    2016-07-07
  • c++ vector(向量)使用方法詳解(順序訪問vector的多種方式)

    c++ vector(向量)使用方法詳解(順序訪問vector的多種方式)

    vector是向量類型,它可以容納許多類型的數(shù)據(jù),如若干個整數(shù),所以稱其為容器,本文介紹一下使用方法
    2013-12-12
  • C++入門之模板基礎(chǔ)講解

    C++入門之模板基礎(chǔ)講解

    這篇文章主要為大家介紹了C++入門之模板基礎(chǔ),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • 老生常談C++ 中的繼承

    老生常談C++ 中的繼承

    這篇文章主要介紹了C++ 中的繼承,本文通過實例代碼給大家介紹的非常詳細對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • C語言實現(xiàn)員工工資管理系統(tǒng)

    C語言實現(xiàn)員工工資管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)員工工資管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++ 實現(xiàn)多數(shù)的最大公約數(shù)的實例

    C++ 實現(xiàn)多數(shù)的最大公約數(shù)的實例

    這篇文章主要介紹了C++ 實現(xiàn)多數(shù)的最大公約數(shù)的實例的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • 詳談浮點精度(float、double)運算不精確的原因

    詳談浮點精度(float、double)運算不精確的原因

    這篇文章主要介紹了詳談浮點精度(float、double)運算不精確的原因,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12

最新評論