2013-05-28 6 views
17

これは値によってラムダ表現を返しますので、コンパイルされません:C++ 11ラムダを参照によって強制的に返すことはできますか?

#include <iostream> 

class Item 
{ 
public: 
    int& f(){return data_;} 
private: 
    int data_ = 0; 
}; 

int main() 
{ 
    Item item; 
    auto lambda = [](Item& item){return item.f();}; 
    lambda(item) = 42; // lambda(item) is a rvalue => compile time error 
    std::cout << item.f() << std::endl; 
    return 0; 
} 

はこれを回避する方法はありますか?ラムダがを参照のために返すように強制できますか

+0

ここで、簡略化されたバージョンのみを教えたラムダについて知りましたか?完全な構文には、戻り値の型を明示的に記述する方法だけでなく、 'mutable'、例外仕様、属性、およびキャプチャの場所も含まれます。私はラムダを最初に教えたときにそれらのいくつかをスキップすることができましたが、リターンタイプではありませんでした。 – bames53

+0

ウィキペディアhttp://en.wikipedia.org/wiki/C%2B%2B11#Lambda_functions_and_expressionsにありました。私は "戻り値の型は暗黙のうちに"読むことを止めました。主な記事には完全な構文が含まれていることが分かります。 –

答えて

35

ラムダの戻り値の型をint&に指定する必要があります。戻り値の型をオフにしておけば、ラムダの形式はreturn expression;となり、戻り値の型は自動的に導出されます。

#include <iostream> 

class Item 
{ 
public: 
    int& f(){return data_;} 
private: 
    int data_ = 0; 
}; 

int main() 
{ 
    Item item; 
    auto lambda = [](Item& item) ->int& {return item.f();}; // Specify lambda return type 
    lambda(item) = 42; 
    std::cout << item.f() << std::endl; 
    return 0; 
} 
+14

C++ 14では、 'auto&'を後続の戻り値の型に書き込むこともできます。戻り値の型が複雑な場合にはよりシンプルになります – Predelnik

関連する問題