适合C 11羔羊的缩进

在C> = 11中格式化lambda表达式是否有接受的“标准”方式?特别是当放入通用算法时.

例如 :

1)

auto it = std::find_if(myVec.begin(),myVec.end(),[id = 42] (const Element& e)
{ return e.id() == id;});

要么
2)

auto it = std::find_if(myVec.begin(),[id = 42] 
                       (const Element& e)
                       { return e.id() == id;});

要么
3)

auto it = std::find_if(myVec.begin(),[id = 42] (const Element& e)
                       { 
                           return e.id() == id;
                       });

或4)

auto it = std::find_if(myVec.begin(),[id = 42] (const Element& e)
{ 
    return e.id() == id;
});

或任何其他回车,空格,制表符的组合
注意:我在我的代码中使用了Allman样式,所以理想情况下它将“适合相同的样式”.

解决方法

我一直倾向于使用自己的语义值赋予相关级别的缩进,并将闭合分隔符与包含其匹配的开头分隔符的行垂直对齐.这使得复杂语句(像那些用lambda表达式作为参数)更容易阅读:
auto it = std::find_if(
  myVec.begin(),[id = 42] (const Element& e){ return e.id() == id;}
);

或者(如果,例如,lambda体太长了一行)

auto it = std::find_if(
  myVec.begin(),[id = 42] (const Element& e){ 
    return e.id() == id;
  }
);

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...