繁体   English   中英

将代码作为参数传递(C ++)

[英]Passing code as an argument (C++)

我如何将代码块传递给C ++中的函数。 在C#中,我可以这样做:

void Example(Action action)
{
    action();
}

Example(() => {
    //do something
});

非常感谢所有帮助和提示。

这是一个简单的例子来开始......

void Example(void (*x)(void))
{
    x();
}

这个电话会......

Example([] { cout << "do something\n"; });

这与您的C#示例非常相似。 正如评论所暗示的那样,有更好,更多样化的方式。 如果您想要返回一个值并获取参数,您可以执行以下操作...

int Example2(int (*y)(int i), int p)
{
    return y(p);
}
// ...
auto ret = Example2([](int p) -> int { cout << p << "\n"; return p; }, 2);

这与C#版本类似,如下所示

int Example2(Func<int,int> y, int p)
{
    return y(p);
}
// ...
var ret = Example2((p) => { /*etc*/ return p; }, 2);

C ++ 11等价物将是:

void Example(const std::function<void()>& action)
{
    // always good to make sure that action has a valid target
    if(action != nullptr)
        action();
}

Example([] {
    //do something
});

std::function<Result(Param1, Param2, ...)>是一个不错的默认值,但你有几个选择:

  1. 声明一个辅助函数并传递一个指向它的指针。 这是用C语言进行处理的唯一方法,也是在C ++ 98中实现它的常规方法。

     void example(void (*action)()) { action(); } void example_action() { std::cout << "action\\n"; } example(example_action); 
  2. 接受函数指针,并传递一个不捕获任何变量的lambda。 Lambda在C ++ 11及更高版本中可用。

     void example(void (*action)()) { action(); } example([]() { std::cout << "action\\n"; }); 
  3. 接受可调用的模板类型参数(一个定义了operator() ),并传递可捕获变量的lambda或任何其他可调用对象(“functor”)。

     template<class F> void example(F action) { action(); } int x = 4; example([x]() { std::cout << "action (" << x << ")\\n"; }); struct example_action { void operator()() { std::cout << "action\\n"; } }; example(example_action()); 
  4. 接受一个std::function对象,并传递一个可以捕获变量的lambda。

     void example(std::function<void()> action) { action(); } int x = 4; example([x]() { std::cout << "action (" << x << ")\\n"; }); 
  5. 声明一个辅助函数并在编译时指向它。

     template<void (*action)()> void example() { action(); } example<example_action>(); 

与任何模板一样,#3将为您调用它的每个操作类型生成example的特殊化,因此它可能会增加您的二进制大小,但它没有运行时开销。 #4将在运行时为闭包分配空间,但只会在二进制文件中生成一个example定义。 #5是罕见的,但它允许传入函数受益于内联等优化。

使用std::function<void()>而不是Action和lambda函数的C ++语法:

void Example(std::function<void()> action)
{
    action();
}

Example([]() {
    //do something
});

与带有函数指针的@Les的解决方案相比, std::function允许您传递捕获上下文的lambdas,以及通常任何其他类型的可调用对象。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM