力为的技术博客

联系 聚合 管理
  154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks
std::list提供了两个排序方法:std::list::sort() 和std::list::sort(_Pr3 _Pred)。
std::list::sort(_Pr3 _Pred)需要提供一个函数对象(仿函数)作为参数。构造函数有多种方式,lambda表达式算是最复合潮流的一种。

比如std::list里面存放的是某个large对象的指针,使用sort()不能满足需求。那可以这样来写:

使用匿名lambda表达式:
std::list<LargeObject*> listObjects;

listObjects.sort([]=(LargeObject* p1, LargeObject* p2)
{
   return *p1 < *p2;
}
);


如果有几个list都要排序,就可以这样写:

具名lambda表达式:

auto compareIt = []=(LargeObject* p1, LargeObject* p2)
{
   return *p1 < *p2;
};

std::list<LargeObject*> listObjects1, listObject2;


listObjects1.sort(compareIt);
listObjects2.sort(compareIt);
posted on 2013-01-20 13:50 力为 阅读(5669) 评论(2)  编辑 收藏 引用 所属分类: 4. C++ FAQ

评论

# re: 用lambda对std::list排序 2013-01-24 15:30 warrior
lambda表达式写错了,[]后不能有=号  回复  更多评论
  

# re: 用lambda对std::list排序 2013-01-24 20:58 力为
被你发现了:)@warrior
  回复  更多评论
  


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理