STL中仿函数是重要的组成部分.所谓的仿函数就是通过重载括号运算符实现的, 如下:
STL库中都是泛型仿函数如小于操作:
![](https://images0.cnblogs.com/blog/339657/201310/07211718-11407db1db584c8dbf28747a2ca9c81d.png)
STL中定义了许多有用的操作,如less(小于), less_equal(小于等于), greater(大于), greater_equal(大于)等.
我们主要看几个函数适配器.
1)bind1st
程序:
![](https://images0.cnblogs.com/blog/339657/201310/07211728-5691d6a3e0fd4deba1734ad447ceb235.png)
输出:
![](https://images0.cnblogs.com/blog/339657/201310/07211735-687473fc30c7418caecd793c45d49b72.png)
bind1st可以将两个参数函数转换成一个参数函数, 是一个简单的委托,上例中bind1st绑定仿函数less<int>()左边的参数, replace_if调用bind1st仿函数时传入less<int>()右边参数,由bind1st将两个参数传入less<int>()中进行实际调用返回结果.
2)bind2nd
程序:
![](https://images0.cnblogs.com/blog/339657/201310/07211747-42bf08d4ed344c42acdbc495ed285f78.png)
输出:
![](https://images0.cnblogs.com/blog/339657/201310/07211803-8968a8a8b2ba435eb02ee818a23c6a3a.png)
可以看到bind2nd和bind1st结果刚好相反,由于bind2nd绑定的是函数的右边参数,因此replace_if调用时传入的是左边参数,
因此结果刚好相反.
3)mem_fun
程序:
![](https://images0.cnblogs.com/blog/339657/201310/07211820-2e541e21575b40a7a513954e4d2fe447.png)
输出:
![](https://images0.cnblogs.com/blog/339657/201310/07211835-a4f3640854864872a91ecdbfc0a1e3d5.png)
mem_fun是一个简单的类成员函数的适配器,也是一个简单的委托.另外mem_fun1允许成员函数拥有一个参数.
下面我们利用bind1st和mem_fun1实现一个例子.
![](https://images0.cnblogs.com/blog/339657/201310/07211859-b552819e96a04871a0d70429228869e7.png)
输出:
![](https://images0.cnblogs.com/blog/339657/201310/07211908-39a8e26880ab47fe80a81b7ee8166d67.png)
我们可以看到,bind1st通过mem_fun1可以绑定类成员函数.
4)ptr_fun
我们自定义的函数能否通过bind1st进行绑定,可以通过ptr_fun这个函数适配器
程序:
![](https://images0.cnblogs.com/blog/339657/201310/07211915-65a2c62b2f344edb9d44d48fff243b9b.png)
输出:
![](https://images0.cnblogs.com/blog/339657/201310/07211922-6030eb710be049a09d4ba6caedab9e3a.png)
调用和mem_fun1函数差不多,原理都一样.