问题描述
如何知道通过复制 lambda 来创建对象是否有成本?
template<typename Lambda>
class A {
public:
A(Lambda lambda) : _lambda(lambda) {} // const Lambda& lambda less efficient?
auto call(double x) { return _lambda(x); }
private:
Lambda _lambda; // is const Lambda& _lambda less efficient?
};
如果 lambda 没有状态,我想知道拥有引用是否代价高昂或无关紧要(与复制 lambda 相同)?
解决方法
如何知道通过复制 lambda 来创建对象是否有成本?
通过使用您打算使用的特定编译器(和开关)进行测试和分析。其他任何事情都是对您尚未确定的实施质量做出假设。
,这里的引用会非常脆弱;如果您将其作为参考,您会遇到错误。
Lambda 本身可以选择成为外部状态的引用;只需复制它们并按值存储它们。如果在特定用例中对此有性能损失,调用者可以避免复制成本。
template<class F>
class A {
public:
explicit A(F f_in) : f(std::move(f_in)) {}
decltype(auto) call(double x) { return f(x); }
private:
F f;
};
只是一些代码质量的变化。
,非常简单的测试表明简单的 lambda 是空对象:
template<typename Lambda>
class Test
{
public:
Test(Lambda _lambda):lambda(_lambda){}
Lambda lambda;
};
int main()
{
const auto lambda=[](double x){return x;};
Test test=lambda;
//print 1 1
std::cout<<sizeof(lambda)<<" "<<sizeof(test)<<std::endl;
return 0;
}