当我最终被宏调用阻止时,我正在使用varargs测试c ++的一些功能。
首先,我有一个班级:
class TestManager
{
public:
void assertTestSeq(int n, ...);
[...]
我希望能够调用此方法,而不必担心 n (varargs的数量)。 所以,我从互联网上复制了那个计算参数数量的宏:
#define NUMARGS(...) NUMARGS_IMPL_((__VA_ARGS__, 63,62,61,60,59,58,57,56,55,54,53,52,51,50,49,48,47,46,45,44,43,42,41,40,39,38,37,36,35,34,33,32,31,30,29,28,27,26,25,24,23,22,21,20,19,18,17,16,15,14,13,12,11,10,9,8,7,6,5,4,3,2,1))
#define NUMARGS_IMPL_(tuple) NUMARGS_IMPL tuple
#define NUMARGS_IMPL(_1,_2,_3,_4,_5, _6, _7, _8, _9,_10,_11,_12,_13,_14,_15,_16,_17,_18,_19,_20,_21,_22,_23,_24,_25,_26,_27,_28,_29,_30,_31,_32,_33,_34,_35,_36,_37,_38,_39,_40,_41,_42,_43,_44,_45,_46,_47,_48,_49,_50,_51,_52,_53,_54,_55,_56,_57,_58,_59,_60,_61,_62,_63,N,...) N
最后,我决定创建一个宏来处理计数:
#define assertSeq(...) (TestManager::*assertTestSeq(NUMARGS(__VA_ARGS__), __VA_ARGS__))
试图称之为:
this->assertSeq(randomSheit1, randSht2);
但是......好吧,我不知道如何声明我的assertSeq宏然后,我不知道如何调用它无论是。你能告诉我这是否可以以某种方式完成以及如何完成?
答案 0 :(得分:2)
最简单的方法是使用可变参数模板:
template<typename Args...> void assertSeq(Args&&... args) {
asserTestSeq(sizeof...(args), std::forward<Args>(args)...);
}
看起来很复杂的&&
和std::forward
内容是启用perfect forwarding。除此之外,sizeof...
给出了参数包的大小,第二个参数是以与assertSeq
相同的方式解包所述包。