我需要记录(用于审计/记录目的)在我的代码中传递的lambda函数的代码。当然,还需要保存lambda对象。所以我想出了一个宏观解决方案如下:
#define LAMBDA_AND_STRING(lambda) lambda, #lambda
using namespace std;
int main(int argc, const char * argv[])
{
auto p = pair<function<void()>, string> ( LAMBDA_AND_STRING( [] {
cout << "Hello world!" << endl;
cout << "Hello again!";
} ) );
cout << "CODE:" << endl << p.second << endl << endl;
cout << "EXECUTION:" << endl;
p.first();
cout << endl;
}
输出:
CODE:
[] { cout << "Hello world!" << endl; cout << "Hello again!"; }
EXECUTION:
Hello world!
Hello again!
这几乎是好的,但是lambda定义的新行已经消失了(实际上我的lambda比上面的原型示例要长得多,所以出于可读性的原因需要保留换行符)。关于如何保留它们的任何想法? (C ++ 11很好)。
谢谢!
答案 0 :(得分:3)
如果我没记错的话,新行甚至不是传递给宏的参数的一部分。这与宏空间折叠相对于宏扩展发生的顺序有关,实际上在预处理器标记化期间剥离了空格。
Foo.cpp中:
#define FOO(a) a
FOO(
one
two
three
)
结果:
$ gcc -E foo.cpp
# 1 "foo.cpp"
# 1 "<command-line>"
# 1 "foo.cpp"
one two three
我认为你运气不好。你可以做一些真的讨厌的事情来解决它:
#define LAMBDA_AND_STRING(lambda) lambda, #lambda
#define NEWLINE
LAMBDA_AND_STRING( [] { NEWLINE
cout << "Hello world!" << endl; NEWLINE
cout << "Hello again!"; NEWLINE
} )
预处理:
[] { cout << "Hello world!" << endl; cout << "Hello again!"; }, "[] { NEWLINE cout << \"Hello world!\" << endl; NEWLINE cout << \"Hello again!\"; NEWLINE }"
现在在打印前替换字符串中的NEWLINE
。