当前位置:首页 > 芯闻号 > 充电吧
[导读]泛型算法中的定制操作很多算法都会比较输入序列中的元素,通过定制比较动作,可以控制算法按照编程者的意图工作。本文以string排序为例进行说明,首先是缺省的排序动作: vector v{"This","

泛型算法中的定制操作


很多算法都会比较输入序列中的元素,通过定制比较动作,可以控制算法按照编程者的意图工作。本文以string排序为例进行说明,首先是缺省的排序动作:

 

vector v{"This","is", "a", "predicate", "."};
sort(v.begin(), v.end());
for(auto s:v){
   cout << s << endl;
}


代码的输出如下:

.

This
a
is
predicate

缺省动作是按照字母顺序排序的。


谓词


假如有一个需求,希望按照字符串长度从小到大排序。可以先定义一个比较函数。


bool compare(const string& s1, const string& s2){
   return s1.size() < s2.size();
}


然后将这个函数传递给sort算法即可:


sort(v.begin(), v.end(), compare);
for(auto s:v){
   cout << s << endl;
}


代码的输出如下:

.

a
is
This
predicate


这种作为参数传递给sort算法的函数可以看作一个动作,它有一个名称:谓词。


lambda表达式


前面的例子中,定义了一个函数传递给sort算法。这个函数可以重复使用还好,如果只是用使用一次的话就显得比较麻烦。这种情况下可以使用C++11提供的新特性:lamada表达式。代码如下:

sort(v.begin(), v.end(),
    [](const string& s1, const string& s2){
       return s1.size() > s2.size();
     });
for(auto s:v){
   cout << s << endl;
}


和使用谓词的情况比较可以看到:

没有定义函数(没有函数名)。

依然定义了动作,参数。


由于执行代码的内容中小于号变成了大于号,代码的输出就变成了下面这样。


predicate
This
is
.
a


这种没有定义函数的指定动作(谓词)的方式就是lambda表达式。


作者观点


lambda表达式在javascript等语言中早已存在,C++终于算是赶上潮流了。




觉得本文有帮助?请分享给更多人。阅读更多更新文章,请扫下面二维码,关注微信公众号【面向对象思考】

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

其实在 c++语言里面const修饰的才算是一个真正的常量,在 c 语言中 const 可以说是个“冒牌货”。为什么会这样?其实是 c++ 编译器对 const 进行了加强,当 c++ 编译器遇到常量声明时,不会像 c...

关键字: c++ C语言 const

返回函数的引用去初始化一个新的引用这个和前面一样,都是不会产生副本,但是现在是用返回值去初始化一个引用声明c,也就是说这时候变成了变量temp的别名,在c的生命周期内temp是一直有效的,这样做完全可以。

关键字: c++ 返回值 引用声明

C++是一种面向对象的高级程序设计语言,是C语言的超集。

关键字: c++ C语言

分析:这是Adobe 公司2007 年校园招聘的最新笔试题。这道题除了考察应聘者的C++ 基本功底外,还能考察反应能力,是一道很好的题目。 在Java 中定义了关键字final ,被final 修饰的

关键字: c++ class

为什么是lambda?讲了这么多天的lambda表达式,有一个很基本的问题没有回答:为什么叫lambda表达式呢?首先这个lambda就是罗马字母λ,lambda表达式即λ表达式。数学上有一个概念叫λ

关键字: c++

        假设我们有个函数用来揭示处理程序的优先权,另一个函数用来在某动态分配所得的Widget 上进行某些带有优先权的处理:int priority () ; void processWi

关键字: c++ effective

判断链表中是否有环最经典的方法就是快慢指针,同时也是面试官大多想要得到的答案。       快指针pf(f就是fast的缩写)每次移动2个节点,慢指针ps(s为slow的缩写)每次移动1个节点,如果快

关键字: c++ 链表 快慢指针

转载请注明出处:http://blog.csdn.net/callon_h/article/details/52073268 引子 上一篇博客从内核驱动到android app讲述了android通过

关键字: c++ java

在网上看到一段读写bmp格式图像的代码,本文对这段代码分成两个函数封装起来方便使用,一个函数是读取bmp格式的图像,一个是向指定文件写入bmp格式的图像。前提我们不需要知道这段代码是如何读取bmp格式

关键字: bmp c++

以前,在lambda表达式没有进入标准的时候,对容器的遍历等涉及到使用函数指针的情况,一般人会懒得使用std::for_each,或std::transform,也许只是一个短短的几句话,却要单独写个

关键字: c++ c++11
关闭
关闭