Biblioteca de utilidades de C ++ - función declval

Descripción

Devuelve una referencia rvalue al tipo T sin hacer referencia a ningún objeto.

Declaración

A continuación se muestra la declaración de la función std :: declval.

template <class T>
   typename add_rvalue_reference<T>::type declval() noexcept;

C ++ 11

template <class T>
   typename add_rvalue_reference<T>::type declval() noexcept;

Parámetros

a, b - Estos son dos objetos.

Valor devuelto

Devuelve una referencia rvalue al tipo T sin hacer referencia a ningún objeto.

Excepciones

Basic guarantee - si la construcción o cesión de tipo T arroja.

Carreras de datos

Llamar a esta función no introduce carreras de datos.

Ejemplo

En el siguiente ejemplo se explica la función std :: declval.

#include <utility>
#include <iostream>

struct A {
   virtual int value() = 0;
};

class B : public A {
   int val_;
   public:
      B(int i,int j):val_(i*j){}
      int value() {return val_;}
};

int main() {
   decltype(std::declval<A>().value()) a;
   decltype(std::declval<B>().value()) b;
   a = b = B(100,20).value();
   std::cout << a << '\n';
   return 0;
}

Compilemos y ejecutemos el programa anterior, esto producirá el siguiente resultado:

2000