C++11 std::function、std::bind和lambda表达式
参考博客: C++可调用对象详解-https://www.cnblogs.com/Philip-Tell-Truth/p/5814213.html
一、关于std::function与std::bind
翻看了几篇博客,还不如看书逻辑性好。以下内容摘自祁宇《深入应用C++11: 代码优化与工程级应用》一书。
有以下4种情况可被称为可调用对象。
1、是一个函数指针。(这里的函数要求是如C函数一样的编译期内存确定的函数指针)
2、是一个具有operator()成员函数的类对象。(让类重载调用操作符operator(),关键在于是以类对象调用形式调用)
3、是一个可被转换为函数指针的类对象。(这一点与2是一样的,函数可以使用函数名+operator的形式调用,也可以使用函数指针如 void(*p)(int); p = test;
(*p) (n); 注意看下面例子中的这一种情况)
4、是一个类成员(函数)指针。
例子:
void func( void) { // ... }
struct Foo {
void operator()( void) { // ... }
};
struct Bar {
using fr_ t = void(*)( void); //void (*)(void)相当定义了一种函数指针类型!!!
static void func( void) { // ... } //一定要是static
operator fr_ t( void) { return func; }
};
struct A{
int a_;
void mem_ func( void) { // ... }
};
使用:
int main( void) {
void(* func_ ptr)( void) = &func; // 1. 函数 指针
func_ ptr();
Foo foo; // 2. 仿 函数
foo();
Bar bar; // 3. 可被 转换 为 函数 指针 的 类 对象
bar();
void (A::* mem_ func_ ptr)( void)= &A:: mem_ func; // 4. 类 成员 函数 指针
int A::* mem_ obj_ ptr = &A:: a_; // 或者是 类 成员 指针
A aa;
(aa.* mem_ func_ ptr)();
aa.* mem_ obj_ ptr = 123;
return 0;
}
std::function是可调用对象的包装器(也就是说std::function对上面几种情况做了封装),可以容纳除了类成员(函数)指针外(不包括上面列出来的4!)的所有可调用对象。通过制定它的模板参数,它可以用统一的方式处理函数、函数对象、函数指针,并允许保存于延迟执行他们。
如定义 std::function<void (void)> fc = func; fc(); //等同于调用func
std::function包括了C++中的可调用对象,让上述列出来的签3中情况就有了一个方便操作的对象属性。
std::bind可以让上面的第4中情况也变成一个方便使用的std::function对象,C++中函数指针的使用一定要上调用者对象。
如下代码:
#include < iostream>
#include < functional>
class A {
public:
int i_ = 0;
void output( int x, int y) { std:: cout << x << " " << y << std:: endl;}
};
int main( void)
{
A a;
std:: function< void( int, int)> fr = std:: bind(& A:: output, &a, std:: placeholders::_ 1 , std:: placeholders::_ 2);
fr( 1, 2);
}
针对类成员函数指针,std::bind就填入了调用者a的地址值,使它变成了一个方便易用的std::function对象。
二、lambda表达式
语法:[ capture ] ( params ) opt -> ret { body; };
其中最有意思的应该是capture这个属性了吧。有空来补充吧,吃饭去!
C++11 std::function、std::bind和lambda表达式的更多相关文章
- C++11 中function和bind以及lambda 表达式的用法
关于std::function 的用法: 其实就可以理解成函数指针 1. 保存自由函数 void printA(int a) { cout<<a<<endl; } std:: ...
- 【转载】C++ function、bind和lambda表达式
本篇随笔为转载,原贴地址:C++ function.bind和lambda表达式. 本文是C++0x系列的第四篇,主要是内容是C++0x中新增的lambda表达式, function对象和bind机制 ...
- c++11——std::function和bind绑定器
c++11中增加了std::function和std::bind,可更加方便的使用标准库,同时也可方便的进行延时求值. 可调用对象 c++中的可调用对象存在以下几类: (1)函数指针 (2)具有ope ...
- C++11 学习笔记 std::function和bind绑定器
C++11 学习笔记 std::function和bind绑定器 一.std::function C++中的可调用对象虽然具有比较统一操作形式(除了类成员指针之外,都是后面加括号进行调用),但定义方法 ...
- c++11新标准for循环和lambda表达式
:first-child { margin-top: 0px; } .markdown-preview:not([data-use-github-style]) h1, .markdown-previ ...
- C++ 11 std::function std::bind使用
cocos new 出新的项目之后,仔细阅读代码,才发现了一句3.0区别于2.0的代码: auto closeItem = MenuItemImage::create( "CloseNorm ...
- C++11学习笔记之三lamda表达式,std::function, std::bind
//lamda //first lamda [] {}; // second lamda []() //or no need () when paramater is null { std::cout ...
- C++11 中的function和bind、lambda用法
std::function 1. std::bind绑定一个成员函数 #include <iostream> #include <functional> struct Foo ...
- std::function,std::bind复习
#include <iostream> #include <functional>//std::bind返回函数对象 void fun1(int a, int b) { std ...
随机推荐
- 刷题总结——系列维护(ssoi)
题目: 题解: 题解如上图,至于计算大于s的数字的数量和小于s数字的和用权值线段树或者树状数组维护就行了···注意离散化 另外发现cout和puts比printf快好多····· 代码: #inclu ...
- 【数位DP】HDU 6156 Palindrome Function
http://acm.hdu.edu.cn/showproblem.php?pid=6156 [AC] #include<bits/stdc++.h> using namespace st ...
- Selenium+Chrome+PhantomJS 爬取淘宝
https://github.com/factsbenchmarks/taobao-jingdong 一 简单铺垫 Selenium负责驱动浏览器与python对接 PhantomJS负责渲染解析Ja ...
- 洛谷 [P3150] pb的游戏
博弈论基础 本题可以视作P2148 E&D 的前置技能 本题直接判断奇偶性来求解, 证明就是2148 的证明 不贴代码
- Resin Thread Dump
[2015/08/25 20:50:13.254] {ThreadLauncher2[ThreadPool[system]]-1} Thread Dump generated Tue Aug 25 2 ...
- msp430项目编程57
msp430综合项目---扩展项目七57 1.电路工作原理 2.代码(显示部分) 3.代码(功能实现) 4.项目总结
- 【转】3年PHPer的面试总结
[转]3年PHPer的面试总结 算法# 1.反转函数的实现# /** * 反转数组 * @param array $arr * @return array */ function reverse($a ...
- es6 递归 tree
function loop(data) { let office = data.map(item => { if(item.type == '1' ||item.type == '2') { i ...
- Codeforces 665D Simple Subset【构造】
题目链接: http://codeforces.com/problemset/problem/665/D 题意: 给定序列,从中找出最大的子集,使得子集中的数两两相加均为质数. 分析: 貌似有用最大团 ...
- dropwizard问题记录1:如何进行mvn package打包,如何在项目目录下运行
dropwizard的helloworld入门教程,跟着教程一步步写很容易,但是最后打包时暴露了自己底子太差的缺陷 mvn package操作 之前工作中完全没有接触过这种打包方式,都是直接打war包 ...