Pregunta ¿Cómo declarar una función que acepta una lambda?


Leí en Internet muchos tutoriales que explicaban cómo usar lambdas con la biblioteca estándar (como std::find), y todos fueron muy interesantes, pero no pude encontrar ninguno que explicara cómo puedo usar un lambda para mis propias funciones.

Por ejemplo:

int main()
{
    int test = 5;
    LambdaTest([&](int a) { test += a; });

    return EXIT_SUCCESS;
}

¿Cómo debo declarar LambdaTest? ¿Cuál es el tipo de su primer argumento? Y luego, ¿cómo puedo llamar a la función anónima que le pasa, por ejemplo, "10" como argumento?


57
2018-05-30 12:20


origen


Respuestas:


Dado que probablemente también quiera aceptar punteros de función y objetos de función además de lambdas, probablemente querrá usar plantillas para aceptar cualquier argumento con un operator(). Esto es lo que hacen las funciones estándar como find. Se vería así:

template<typename Func>
void LambdaTest(Func f) {
    f(10);
}

Tenga en cuenta que esta definición no utiliza ninguna característica c ++ 0x, por lo que es completamente compatible con versiones anteriores. Es solo la llamada a la función usando expresiones lambda que es específica de c ++ 0x.


56
2018-05-30 12:25



Si no desea crear una plantilla, puede hacer lo siguiente:

void LambdaTest (const std::function <void (int)>& f)
{
    ...
}

56
2018-05-30 12:32



Me gustaría contribuir con este ejemplo simple pero autoexplicativo. Muestra cómo pasar "cosas invocables" (funciones, objetos de función y lambdas) a una función o a un objeto.

// g++ -std=c++11 thisFile.cpp

#include <iostream>
#include <thread>

using namespace std;

// -----------------------------------------------------------------
class Box {
public:
  function<void(string)> theFunction; 
  bool funValid;

  Box () : funValid (false) { }

  void setFun (function<void(string)> f) {
    theFunction = f;
    funValid = true;
  }

  void callIt () {
    if ( ! funValid ) return;
    theFunction (" hello from Box ");
  }
}; // class

// -----------------------------------------------------------------
class FunClass {
public:
  string msg;
  FunClass (string m) :  msg (m) { }
  void operator() (string s) {
    cout << msg <<  s << endl; 
  }
};

// -----------------------------------------------------------------
void f (string s) {
  cout << s << endl;
} // ()

// -----------------------------------------------------------------
void call_it ( void (*pf) (string) ) {
  pf( "call_it: hello");
} // ()

// -----------------------------------------------------------------
void call_it1 ( function<void(string)> pf ) {
  pf( "call_it1: hello");
} // ()

// -----------------------------------------------------------------
int main() {

  int a = 1234;

  FunClass fc ( " christmas ");

  f("hello");

  call_it ( f );

  call_it1 ( f );

  // conversion ERROR: call_it ( [&] (string s) -> void { cout << s << a << endl; } );

  call_it1 ( [&] (string s) -> void { cout << s << a << endl; } );

  Box ca;

  ca.callIt ();

  ca.setFun (f);

  ca.callIt ();

  ca.setFun ( [&] (string s) -> void { cout << s << a << endl; } );

  ca.callIt ();

  ca.setFun (fc);

  ca.callIt ();

} // ()

4
2017-12-23 22:35