bind函数定义在头文件 functional 中。可以将 bind 函数看作一个通用的函数适配器,它接受一个可调用对象,生成一个新的可调用对象来“适应”原对象的参数列表。
bind函数:接收一个函数名作为参数,生成一个新的函数。
auto newCallable = bind(callbale, arg_list);
arg_list中的参数可能包含入_1, _2等,这些是新函数newCallable的参数。
在这篇博客lambda 表达式 介绍 中,讨论了find_if的第三个参数的问题,当时是用lambda表达式解决的,有了bind函数后,也可以用bind函数解决。
解决办法:bind(check_size, _1, sz)
auto idx = find_if(svec.begin(),svec.end(),bind(check_size, _1, 6));
其实,newCall= bind(check_size, _1, sz)返回了一个新的函数newCall ,这个newCall 只接受一个参数,正好满足find_if的要求。
•从find_if的角度来看,啊,newCall是含有一个参数的函数,OK,没问题。
•从程序猿的角度看,check_size是含有2个参数的函数,只是提前把sz(6)绑定到了newCall上了,
•当调用newCall(s),实际是调用了check_size(s, 6),相当于newCall也有2个参数,只是第二个参数有个默认值为6。newCall(const string &s, size_t sz = 6); ,所以调用newCall时,传递一个参数就够了。
注意:_1,_2等,是放在了命名空间placeholder中,所以要使用:
//_1,_n定在std::placeholders里面 using namespace std::placeholders;
bind参数用法:
//g是以个有2个参数的可调用对象 auto g = bind(func, a, b, _2, c, _1);//func是有5个参数的函数
调用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实现了和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改变原来函数的参数的位置 //升序 vector<string> svec{"aab","d","aa","bb","e","bbb"}; sort(svec.begin(), svec.end(), shorter); for(auto const &s : svec){ cout << s << " "; } cout << endl; //由于调换了shorter参数的位置,所以变成了降序 sort(svec.begin(), svec.end(),bind(shorter, _2, _1)); for(auto const &s : svec){ cout << s << " "; } cout << endl; */ //bind引用,必须使用ref或者cref函数,把对象转化成引用,不能用& 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; }
总结
以上所述是小编给大家介绍的c/c++ 标准库 bind 函数详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
C++ 标准库可以分为两部分: 标准函数库: 这个库是由通用的、独立的、不属于任何类的函数组成的。函数库继承自 C 语言。 面向对象类库: 这个库是类及其相关函数的集合。 C++ 标准库包含了所有的 C 标准库,为了支持类型安全,做了一定的添加和修改。 标准函数库 标准函数库分为以下几类: 输入/输出 I/O 字符串和字符处理 数学 时间、日期和本地化 动态分配 其他 宽字符函数 面向对象类库 标
本文向大家介绍C标准库 的实现详解,包括了C标准库 的实现详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲解了C标准库<assert.h>的实现过程及相关用法。分享给大家供大家参考。具体分析如下: 一、背景知识 头文件<assert.h>唯一的目的就是提供assert宏定义,可以在程序中关键的地方使用这个宏来进行断言。如果一处断言被证明非真,希望程序在标准错误流输出一条适当的提示信息,并使
标准c数学函数 -> 详解 标准c数学函数 abs 语法: #include <stdlib.h> int abs( int num ); 功能: 函数返回参数num.的绝对值。例如: int magic_number = 10; cout << "Enter a guess: "; cin >> x; cout << "Your guess was " << abs( magic_n
其他标准c函数 -> Details 其他标准c函数 abort 语法: #include <stdlib.h> void abort( void );功能: 终止程序的执行。返回值依赖于执行,可以通过返回值显示错误。 相关主题: exit() and atexit(). assert 语法: #include <assert.h> void assert( int exp );功能: 宏asse
其他标准c函数 其他标准c函数 abort() 停止程序执行 assert() 当表达式非真,停止程序执行 atexit() 当程序退出执行设定的程序 bsearch() 执行折半查找 exit() 停止程序执行 getenv() 获取指定环境变量的值 longjmp() 从设定点执行程序 qsort() 执行快速排序 raise() 向程序发送信号 rand() 返回一个随机数 setjmp()
标准c内存函数 -> 详解 标准c内存函数 calloc 语法: #include <stdlib.h> void *calloc( size_t num, size_t size ); 功能: 函数返回一个指向num 数组空间,每一数组元素的大小为size。如果错误发生返回NULL。 相关主题: free(), malloc(), and realloc(). free 语法: #incl