重复使用嵌套循环,无需复制和粘贴

Rug*_*rra 7 c++ macros foreach loops nested-loops

假设我有这个嵌套循环

for (int a=1; a<MAX_A; ++a)
  for (int b=1; b<MAX_B; ++b)
    for (int c=1; c<MAX_C; ++c)
    {
       do_something(a, b ,c);
    }
Run Code Online (Sandbox Code Playgroud)

我在代码的各个部分重用了这个循环,改变了函数do_something.每次前三行重写都很无聊.例如,在python中我会创建一个生成器来返回迭代器(1, 1, 1), (1, 1, 2), ...或类似的东西itertools.product.

在c ++中,我唯一想到的解决方案就是定义一个宏.还有更好的东西吗?

Sve*_*ven 11

使用模板:

template<typename Func>
inline void do_something_loop(Func f)
{
    for (int a=1; a<MAX_A; ++a) 
      for (int b=1; b<MAX_B; ++b) 
        for (int c=1; c<MAX_C; ++c) 
        { 
           f(a, b ,c); 
        } 
}
Run Code Online (Sandbox Code Playgroud)

这可以使用与签名匹配的任何函数指针或函数对象调用,例如:

void do_something(int a, int b, int c) { /* stuff */ }

do_something_loop(do_something);
Run Code Online (Sandbox Code Playgroud)

或者使用函数对象:

struct do_something
{
    void operator()(int a, int b, int c) { /* stuff */ }
};

do_something_loop(do_something()); 
Run Code Online (Sandbox Code Playgroud)

或者,如果您的编译器支持C++ 11,即使使用lambda:

do_something_loop([](int a, int b, int c) { /* stuff */ });
Run Code Online (Sandbox Code Playgroud)

请注意,您也可以将f参数声明为带有签名的函数指针,void(*f)(int,int,int)而不是使用模板,但这不太灵活(它不适用于函数对象(包括std :: bind的结果)或lambdas).