C++ Primer 学习笔记:泛型算法入门 参数绑定bind
2018-01-02 10:24
375 查看
bind函数的基本介绍
bind函数的最根本的作用就是可以把一个参数较多的函数给封装成参数较少的函数,因此对于上述find_if函数的问题,我们可以自定义一个含俩个参数的函数,然后通过bind函数进行封装,使之变成含一个参数的新函数(新函数会调用原来的函数),这样新函数就可以被find_if函数的第三个参数所使用了,bind位于头文件functional之内bind的基本形式与使用
bind函数定义在头文件functional中,我们可以将bind函数看作一个通用的函数适配器,它的一般形式如下auto newFun = bind(oldFun,arg_list);
参数oldFun是需要bind封装的源函数,newFun是封装了参数后的old_Fun,arg_list是一个逗号分割的参数列表,对应oldFun的参数,即当我们调用newFun是,它会调用oldFun并且会把参数列表中的参数传给oldFun
arg_list中会包含_n的名字,此类名字的参数又名”占位符”,因为其占据了newCallable的参数的位置,其中_n中的n表示它占据了new_Fun函数中
4000
的第几个参数。
函数的基本形式介绍完了,那么就进入整体,来为大家展示一个bind函数在解决find_if问题上是如何做的
实例如下
#include<iostream> #include<vector> #include<algorithm> #include<functional> using namespace std; bool check_size(const int x,int sz) { return x > sz; } int main(void) { vector<int> v = {1,2,3,4,5,6,7,8,9}; int n = 5; //有bind函数新封装生成的函数,其内部调用了check_size auto new_check_size = bind(check_size,std::placeholders::_1,n); auto it = find_if(v.begin(),v.end(),new_check_size); cout<<"第一个大于n的数为:"<<*it<<endl; return 0; }
其实用的高端一点,使用上述的做法很不错,但是要是遇到一个很简单的问题,直接写死也可以,或者调用全局变量,也不一定非得用bind绑定函数
用bind重排源函数的参数顺序
用bind重排源函数的参数顺序只需将新函数与源函数的参数列表进行跌倒即可实现代码如下
//假定源函数如下 bool oldFun(int a1,int a2); //使用bind封装源函数如下 auto newFun = bind(old_Fun,_2,_1);
使用ref给源函数传递引用参数
如果我们想像lambda表达式一样传递引用,那么就得使用标准库中的ref函数,与其类似的是cref其生成的引用是const类型的具体实例如下
#include<iostream> #include<vector> #include<algorithm> #include<functional> using namespace std; bool check_size(const int x,int &sz) { //改变sz的值 sz = 6; return x > sz; } int main(void) { vector<int> v = {1,2,3,4,5,6,7,8,9}; int n = 5; //传递n的引用 auto new_check_size = bind(check_size,std::placeholders::_1,ref(n)); auto it = find_if(v.begin(),v.end(),new_check_size); cout<<"n的值为为:"<<n<<endl; return 0; }
相关文章推荐
- C++ Primer 学习笔记:泛型算法入门 插入迭代器 && iostream迭代器 && 反向迭代器
- C++ Primer 学习笔记:泛型算法入门 fill && back_inserter && copy && replace
- C++ Primer 学习笔记:泛型算法入门 特定容器算法
- C++ Primer复习和学习笔记 第十一章 泛型算法
- 《C++ Primer》第10章:泛型算法 学习笔记总结
- 简述泛型算法之 三bind_参数绑定
- C++ Primer 学习笔记:泛型算法入门 find && accumulate && equal
- 《c++ primer》第10章 泛型算法 学习笔记
- C++ Primer 学习笔记_45_STL实践与分析(19)--泛型算法的结构
- C++ primer第二次阅读学习笔记(第11章:泛型算法)
- C++ primer第二次阅读学习笔记(第11章:泛型算法)
- 【C++ Primer 学习笔记】: 容器和算法之【泛型算法】
- 5.3.vue入门基础学习笔记-基础指令介绍(属性绑定v-bind)
- Introduction to Algorithms 算法导论 第2章 算法入门 学习笔记及习题解答
- C++ Primer 学习笔记_46_STL实践与分析(20)--容器特有的算法
- scala 学习笔记(03) 参数缺省值、不定个数参数、类的属性(Property)、泛型初步
- 算法导论学习笔记-第二章-算法入门
- 【C++ Primer 学习笔记】: 容器和算法之【顺序容器】
- (算法竞赛入门)埃及分数问题学习笔记
- C++ Primer : 第十章 : 泛型算法 之 lambda表达式和bind函数