这几行作为C中的小型测试框架做了什么?

嗨,我正在阅读std :: optional here的实现,我在其单元测试文件中找到以下行.
struct caller {
    template <class T> caller(T fun) { fun(); }
};
# define CAT2(X,Y) X ## Y
# define CAT(X,Y) CAT2(X,Y)
# define TEST(NAME) caller CAT(__VAR,__LINE__) = []

我真的不明白这些线是做什么的.调用者似乎是一个调用函数的模板,但它如何用作调用者CAT …?
X ## Y在这里是什么意思?稍后在文件中,用户使用TEST定义单元测试,但它们没有出现在任何可执行代码中(我的意思是它们至少不在main函数调用),所以我甚至不确定编译的二进制文件是否实际运行了测试.你能解释一下这里发生了什么吗?谢谢!

编辑:非常确定在运行二进制文件时执行测试,但是如何实现?

解决方法

您可以在预处理后查看输出(-E表示gcc)…

这是我添加宏的用法代码

struct caller {
    template <class T> caller(T fun) { fun(); }
};
# define CAT2(X,__LINE__) = []

TEST(disengaged_ctor) { foo(); };

after preprocessing the last line turns to:

caller __VAR10 = []{ foo(); };

我对__VAR和未使用的NAME *感到有些困惑.但是,[] {foo();用于创建调用者的lambda是在调用者构造函数调用的.

* =我想这个想法如下:假设你收到一条错误信息,说__VAR10中有错误,然后在第10行找到TEST(disengaged_ctor),即.失败测试的名称.

相关文章

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