C++11 function使用

简介: function是一组函数对象包装类的模板,实现了一个泛型的回调机制。 引入头文件 #include using namespace std;using namespace std::placeholders;  //bind的时候会用` 参考:http://www.

function是一组函数对象包装类的模板,实现了一个泛型的回调机制。

引入头文件

#include <functional>
using namespace std;
using namespace std::placeholders;  //bind的时候会用`

参考:http://www.cnblogs.com/hujian/archive/2012/12/07/2807605.html

fuction  bind:http://blog.csdn.net/fjb2080/article/details/7527715

我们可以调用的对象有很多,比如普通函数、函数指针、lanmbda表达式、函数对象和类的成员函数等。

不管采用哪种方式,主要调用形式一样(返回值类型、传递给调用的实参类型),我们就可以使用同一种形式来调用。

这个时候就可以用到function模板,它给予我们在调用的方式上更大的弹性。

请看一下三种不同的函数定义:

 

[cpp]  view plain  copy
 
 print?
  1. int add(int a, int b){  
  2.     return a+b;  
  3. }  
  4. auto mod=[](int a, int b){return a%b;};  
  5. struct divide{  
  6.     int operator()(int m, int n){  
  7.         return m/n;  
  8.     }  
  9. };  

 

这三种都可以使用同一种调用形式,int(int, int),调用方式如下:

 

[cpp]  view plain  copy
 
 print?
  1. function<int(int,int)> func1= add;  
  2. function<int(int,int)> func2= divide();  
  3. function<int(int,int)> func3= mod;  
  4. cout<<func1(5, 6)<<endl;  
  5. cout<<func2(5, 6)<<endl;  
  6. cout<<func3(5, 6)<<endl;  


学会了使用function,可以继续如下进行抽象定义,不同类型采用相同的调用方法:

 

 

[cpp]  view plain  copy
 
 print?
  1. map<string,function<int(int, int)>> funs =  
  2. {  
  3.     {"+", add},  
  4.     {"-", std::minus<int>()},//标准库的函数,参数为两个整数,可以参考前一篇博客  
  5.     {"/", divide()},//类成员函数  
  6.     {"*", [](int i,int j){return i*j;}},//lambda表达式  
  7.     {"%", mod},  
  8. };  
  9. funs["+"](4,6);  


以上就是function的简单使用。下面是从另一篇博客转载的,使用function的引用来保存函数对象。考虑下面代码:

 

 

[cpp]  view plain  copy
 
 print?
  1. class CAdd  
  2. {  
  3. public:  
  4.     CAdd():m_nSum(0){NULL;}  
  5.     int operator()(int i)  
  6.     {  
  7.         m_nSum += i;  
  8.         return m_nSum;  
  9.     }  
  10.       
  11.     int Sum() const  
  12.     {  
  13.         return m_nSum;  
  14.     }  
  15.       
  16. private:  
  17.     int m_nSum;  
  18. };  
  19. int main(int argc, const char * argv[])  
  20. {  
  21.     CAdd cAdd;  
  22.     function<int(int)> funcAdd1 = cAdd;  
  23.     function<int(int)> funcAdd2 = cAdd;  
  24.     cout<<funcAdd1(10)<<endl;  
  25.     cout<<funcAdd2(10)<<endl;  
  26.     cout<<cAdd.Sum()<<endl;  
  27.       
  28.      return 0;  
  29. }  

 

上面的输出结果是 10 10 0。我们将同一个函数对象赋值给了两个function,然后分别调用这两个function,但函数中的成员变量的值没有保存,问题在哪里?因为function的缺省行为是拷贝一份传递给它的函数对象,于是f1,f2中保存的都是cAdd对象的拷贝。

C++11提供了ref和cref函数来提供对象的引用和常引用的包装。要是function能够正确保存函数对象的状态,可以如下修改代码:

 

[cpp]  view plain  copy
 
 print?
  1. function<int(int)> funcAdd3 = ref(cAdd);  
  2. function<int(int)> funcAdd4 = ref(cAdd);  
  3. cout<<funcAdd3(10)<<endl;  
  4. cout<<funcAdd4(10)<<endl;  
  5. cout<<cAdd.Sum()<<endl;  

 

 

        另外,两个function之间赋值时,如果源function保存的是函数对象的拷贝,则目标function保存的也是函数对象的拷贝。如果源function保存的是对函数对象的引用,则目标function保存的也是函数对象的引用。

目录
相关文章
|
4月前
|
消息中间件 Kubernetes NoSQL
c++ 11 中 function,lambda,bind
c++ 11 中 function,lambda,bind
|
3天前
|
存储 算法 对象存储
【C++入门到精通】function包装器 | bind() 函数 C++11 [ C++入门 ]
【C++入门到精通】function包装器 | bind() 函数 C++11 [ C++入门 ]
13 1
|
4月前
|
C++
C++高级开发之可调用对象、function、bind(2)
std::bind 绑定器   要使用这个函数模板,在 cpp文件前面要包含如下头文件#include<funcitonal>   std::bind能够将对象以及相关的参数绑定到一起,绑定完成后可以直接调用,也可以用
30 0
|
17天前
|
Java 编译器 Linux
【C++11(二)】lambda表达式以及function包装器
【C++11(二)】lambda表达式以及function包装器
|
2月前
|
存储 安全 编译器
【C++ 包装器类 std::function 和 函数适配器 std::bind】 C++11 全面的std::function和std::bind的入门使用教程
【C++ 包装器类 std::function 和 函数适配器 std::bind】 C++11 全面的std::function和std::bind的入门使用教程
34 0
|
4月前
|
存储 编译器 C++
C++ 包装器—function
C++ 包装器—function
|
4月前
C++11实用技术(二)std::function和bind绑定器
C++11实用技术(二)std::function和bind绑定器
27 0
|
4月前
|
自然语言处理 Java 编译器
C++中function,bind,lambda
C++中function,bind,lambda
C++中function,bind,lambda
|
4月前
|
C++
C++高级开发之可调用对象、function、bind(1)
可调用对象   以前函数调用总是离不开一堆圆括号,没错“()”就是函数调用的一个明显标记,这个 “()”有一个称呼叫函数调用运算符。
45 0
|
10天前
|
存储
function(函数)
在 Lua 中,函数作为第一类值可存储于变量,如示例所示:`factorial1` 和 `factorial2` 存储相同函数。此外,函数可作为参数传递,如 `testFun` 接收一个表和一个匿名函数,该匿名函数在迭代中处理键值对,输出 `key1=val1` 和 `key2=val2`。

热门文章

最新文章