私はクライアントがクラスのフィールドとして[]() -> void {}
のようなラムダ式を格納することができるクラスを作成したいと思いますが、その方法を理解することはできません。 One answer suggested using decltype
、私はそれを成功させようとしました。ここにはideone source linkがあります。下記のソースと結果である:ラムダ式をC++ 11のクラスのフィールドとして保存するにはどうすればよいですか?
#include <cstdio>
auto voidLambda = []()->void{};
class MyClass {
public:
decltype(voidLambda) t;
MyClass(decltype(voidLambda) t) {
this->t = t;
}
};
int main() {
MyClass([] {
printf("hi");
});
}
結果:
prog.cpp: In constructor 'MyClass::MyClass(<lambda()>)':
prog.cpp:3:79: error: no matching function for call to '<lambda()>::__lambda0()'
prog.cpp:2:20: note: candidates are: <lambda()>::<lambda>(const<lambda()>&)
prog.cpp:2:20: note: <lambda()>::<lambda>(<lambda()>&&)
prog.cpp:3:88: error: no match for 'operator=' in '((MyClass*)this)->MyClass::t = t'
prog.cpp: In function 'int main()':
prog.cpp:5:27: error: no matching function for call to 'MyClass::MyClass(main()::<lambda()>)'
prog.cpp:3:48: note: candidates are: MyClass::MyClass(<lambda()>)
prog.cpp:3:14: note: MyClass::MyClass(const MyClass&)
は誰もがこれを行う方法を知っていますか?
すべてのラムダ式は、それ自身のユニークなタイプを作成します。 'auto A = [](){};では、 auto B = [](){}; '' A'と 'B'は同じ型ではありません。 – bames53
残念ながら 'struct A {auto x = 0; }; 'は許されません。 –