Share via


unary_function<> Structure

muestra cómo utilizar la estructura de unary_function<> en Visual C++.

template<class _A, class _R>
   struct unary_function
   {
      typedef _A argument_type;
      typedef _R result_type;
   };

Comentarios

[!NOTA]

La clase y los nombres de parámetro en el prototipo no coincide con la versión del archivo de encabezado.Algunos se han modificado para mejorar la legibilidad.

se utilizaunary_function como clase base para definir mejor las funciones de operador en el formato siguiente:classname deResult_Type::operadorX(Argument_Type).

Ejemplo

// unary_function.cpp
// compile with: /EHsc
//
// Structure used:
//       unary_function<int, float> - allows us
//       to write operator functions accepting an
//       integer and returning floats.
////////////////////////////////////////////

#include <functional>
#include <iostream>

using namespace std ;

/* derive class from unary_function in order to use it */

class unary_test : public unary_function<int,float>
{
public:
  float value;
  unary_test(){value=10.0;}
  unary_test(float x){value=x;}
  result_type operator*(argument_type x);
  result_type operator-(argument_type x);
};

/* You can now easily create operators that accept */
/* an int and return a float.                     */

unary_test::result_type unary_test::operator*(unary_test::argument_type x)
{
  float tmp = value * (float)x;
  cout << "Value after * is " << tmp << endl ;
  return value;
}

unary_test::result_type unary_test::operator-(unary_test::argument_type x)
{
  float tmp = value - (float)x;
  cout << "Value after minus is " << tmp << endl ;
  return tmp;
}

int main(void)
{
  unary_test item;
  unary_test item2(18.0);

  cout << "Begin" << endl ;
  cout.setf(ios::fixed) ;
  item = item * 2;
  item2 = item2 - 5;
}
  

Requisitos

encabezado: <funcional>

Vea también

Conceptos

Ejemplos de biblioteca de plantillas estándar