头文件:#include<functional>
std::bind函数类似于容器适配器,这是一个函数适配器。
形式:auto newCallable = bind(callable , arg_list);
callable:被绑定的函数
newCallable:可调用对象(【c++】可调用对象(Callable Objects)_c++ callable_七秒钟笔记的博客-CSDN博客)
arg_list:参数列表,里面有如std::placeholders::_n的参数占位符,n表示参数的序号,比如说_1就是第一个参数,_2就是第二个参数。
解释:arg_llist参数列表对应被绑定的函数callable的参数列表,当我们调用newCallable的时候就是调用callable函数,对newCallable函数的传参就是对callable函数的相应位置传参。
注意:bind函数里的绑定参数是以拷贝的方式传递的,所以要绑定的参数类型必须可以拷贝。
例如:
bool check_size(const string &s,size_type sz)
{
if(s.length()<sz)
return true;
else
return false;
}
auto check = std::bind(check_size,std::placeholders::_1,sz);
bool ischeck=check(str);
/*
当调用check的时候,需要给check传参,给check传的参数会传给相应的占位符的位置
*/
find_if(vec.begin(),vec.end(),bind(check_size,std::placeholders::_1,sz));
bind函数的使用:
1.用bind函数重排参数顺序,绑定函数从左只有,分别对应bind函数里的_1、_2、_3......_n,这样就可以重新排列被绑定函数的参数顺序,如:
func(a,b,c,d,e); //比如有一个函数有五个参数
auto f=bind(func,val1,val2,_2,val3,_1);
f(one,two);
/*
调用f,给f传的参数one和two,分别对应bind函数里的_1和_2
即,func(val1,val2,two,val3,one);
*/
2.绑定引用参数,因为bind函数是拷贝函数,所以当碰到无法拷贝的参数的类型时就会出错,这时候可以使用绑定引用参数的方式来进行参数的绑定,此时就要使用std::ref和std::cref函数,也放在头文件#include<functional>里,作用是:返回一个对象,包含给定的引用,并且此对象是可以拷贝的,cref()生成的是一个保存const引用的类,如:
for_each(words.begin(),words.end(),bind(print,ref(os),_1,''));
//os是ostream类型,输入输出流类型不允许拷贝,所以只能使用ref引用绑定参数的方式
3.使用成员函数隐式参数this指针, 因为每个成员函数的参数列表里都有个隐式参数this指针,有时候你可以看到这样的bind函数:std::bind(&Class:ClassFunc, parent_, parament); 这里的parent_就是填充ClassFunc的隐式参数,parent_一般是指向Class的指针,作为this指针,传入ClassFunc成员函数里。