c++函数扩展操作

lambda表达式[=&]()mutable->{}()

ISO C++ 11 标准的一大亮点是引入Lambda表达式。基本语法如下:

[capture list] (parameter list) -> return type { function body }

主要用于解决函数内部函数定义的问题。例如调用中的std::sort,ISO C++ 98 的写法是要先写一个compare函数:

bool compare(int& a,int& b)
{
    return a>b;
}

然后,再这样调用:

sort(a, a+n, compare);

然而,用ISO C++ 11 标准新增的Lambda表达式,可以这么写:

sort(a, a+n, [](int a,int b){return a>b;});//降序排序

这样一来,代码明显简洁多了。

[](char *language)->char * {cout<<"hello "<<language<<endl; }("lambda");

//auto fun(char *language)->char * =  [] { cout<<"hello lambda"<<endl; };
//fun("lambda");
//=只读,只能指定全部,&可单个指定,可多个指定
//mutable读原本,写副本

函数包装器

#include
c++风格的函数指针

  function<int (int, int)> add = [](int a, int b)->int{return a+b;};
  cout<<add(1, 2)<<endl;

模板元

递归函数返回需要时间,模板元用于递归加速(运行时间转化为编译时间),游戏里使用比较多。

long climb(int n){
    if (1==n) {
        return 1;
    }else if (2==n){
        return 2;
    }else{
        return climb(n-1)+climb(n-2);
    }
}


template<int N>
struct Climb{
    enum{
        res=Climb<N-1>::res +Climb<N-2>::res
    };
};

template<>
struct Climb<1>
{
    enum { res = 1};
};

template<>
struct Climb<2>
{
    enum { res = 2};
};

调用时只支持常量,不支持变量

//Climb<30>::res fast than climb(30);
cout<<"have "<<Climb<30>::res<<" kinds of function to climb 30 steps"<<endl;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

群野

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值