我正在用 C++ 编写一个程序,我应该将不同的函数嵌入到同一个 for
循环中。
例子:
for(i = 0; i < N_ITER; i++) {
/* ... */
function_A();
/* ... */
}
for(i = 0; i < N_ITER; i++) {
/* ... */
function_B();
/* ... */
}
出于性能考虑,我必须将 function_A
和 function_B
内联到此函数中。我的第一个解决方案是使用仿函数和函数模板,如下所示:
class function_A {
public:
void operator()() {
/* ... */
}
};
class function_B {
public:
void operator()() {
/* ... */
}
};
template <class T>
class run {
public:
void operator()() {
/* ... */
T func;
for (i = 0; i < N_ITER; i++) {
/* ... */
func();
/* ... */
}
/* ... */
}
};
我可以这样调用函数:
run<function_A>()();
run<function_B>()();
但很快我发现代码中有太多重复的仿函数定义 class xxx { public: void operator()() {...} };
并且看起来很别扭。
所以我变成了一个使用 lambda 的解决方案:
auto function_A = []()
{
/* ... */
};
auto function_B = []()
{
/* ... */
};
template <class T>
class run {
public:
T func;
run(T func) : func(func) {}
void operator()() {
/* ... */
for (i = 0; i < N_ITER; i++) {
/* ... */
func();
/* ... */
}
/* ... */
}
};
但是这次更难调用这些函数:
run<decltype(function_A)> funcA(function_A); funcA();
run<decltype(function_A)> funcB(function_A); funcB();
而且不像之前的解决方案那么清晰。
有没有更优雅的 C++ 实现方式?我错过了什么吗? 任何建议将不胜感激!!!
最佳答案
试试这个:
void run(std::function<void(void)> fn)
{
for (int i = 0; i < N_ITER; i++)
fn();
}
(...)
auto lambda1 = []()
{
std::cout << "Hello, world!\n";
};
run(lambda1);
准备好这样的run
函数/方法后,您也可以这样做:
class C
{
public:
void operator()()
{
printf("Hello world from a functor!\n");
}
};
(...)
C c;
run(c);
编辑:回应评论:
以前的解决方案没有内联。然而,这是:
template <typename T>
void run2(T fn)
{
for (int i = 0; i < 10; i++)
fn();
}
int main(int argc, char * argv[])
{
getchar();
auto lambda1 = []()
{
std::cout << "Hello, world!\n";
};
run2(lambda1);
getchar();
}
反汇编:
auto lambda1 = []()
{
std::cout << "Hello, world!\n";
};
run2(lambda1);
002E1280 mov ecx,dword ptr ds:[2E3044h]
002E1286 call std::operator<<<std::char_traits<char> > (02E1730h)
002E128B dec esi
002E128C jne main+10h (02E1280h)
实际上,在 run2 的情况下使用仿函数的解决方案也是内联的,虽然有点长:
C c;
run2(c);
01031293 mov esi,0Ah
01031298 jmp main+30h (010312A0h)
0103129A lea ebx,[ebx]
010312A0 mov ecx,dword ptr ds:[1033044h] \
010312A6 mov edx,10331ACh |
010312AB call std::operator<<<std::char_traits<char> > (01031750h) > loop
010312B0 dec esi |
010312B1 jne main+30h (010312A0h) /
关于c++ - 在一个函数中嵌入不同的函数 : functor or lambda?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17229226/