正在将动态数组元素解析为参数?(变音符)

Parsing dynamic-array elements as arguments? (variadic)

本文关键字:参数 音符 动态 数组元素      更新时间:2023-10-16

试图找到一个(可能)预处理技巧,它将做类似于下一个伪C++的事情

myVariadicFun(argv[0],argv[1],argv[2],...,argv[argc] );

variadic函数已经准备好并可以工作,只需要解析其中的数组参数。

之所以不只是传递一个数组指针,是因为我实际上在玩constexpr/元编程。

否,根据定义,您不能使用带有编译时间大小推导的动态大小数组(即其大小在执行时定义)。

使用[Boost.Preprocessor],您可以轻松地根据屏幕截图中描述的需求生成适当的代码:

#include <boost/preprocessor/repetition/enum.hpp>
#define ARRAY_ELEMENTS(z, n, arrVar) arrVar[n]
#define EXPAND_ARRAY(N, arrVar) 
  BOOST_PP_ENUM(N, ARRAY_ELEMENTS, arrVar)
#define EXPAND_CASE(N, arrVar) 
    case N: cout << crawler(EXPAND_ARRAY(N, arrVar)).best_sum << endl; break
int main(int argc, char* argv[]) {
    char** input = &argv[1];
    --args;
    switch(argc) {
    EXPAND_CASE(1, input);
    EXPAND_CASE(2, input);
    EXPAND_CASE(3, input);
    }
}

BOOST_PP_REPEAT_FROM_TO允许执行进一步的代码折叠:

#include <boost/preprocessor/repetition/enum.hpp>
#include <boost/preprocessor/repetition/repeat_from_to.hpp>
#define ARRAY_ELEMENTS(z, n, arrVar) arrVar[n]
#define EXPAND_ARRAY(N, arrVar) 
  BOOST_PP_ENUM(N, ARRAY_ELEMENTS, arrVar)
#define EXPAND_CASE_Z(z, N, arrVar) 
 case N: cout << crawler(EXPAND_ARRAY(N, arrVar)).best_sum << endl; break;
// actually each OS has its own limitation for maximal number of arguments, see your
// OS docs for more info. Beware Boost.Preprocessor has its own limits for repeatable
// macros expansions
#define MAX_ARGS 100
int main(int argc, char* argv[]) {
    char** input = &argv[1];
    --args;
    switch(argc) {
    BOOST_PP_REPEAT_FROM_TO(1, MAX_ARGS, EXPAND_CASE_Z, input);
    }
}

但坦率地说,我怀疑可变模板函数是否打算以这种方式使用。