Espacios de nombres
Variantes
Acciones

std::is_function

De cppreference.com
< cpp‎ | types
 
 
Biblioteca de metaprogramación
Rasgos de tipo
Categorías de tipo
(C++11)
(C++11)(DR*)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
is_function
(C++11)
(C++11) 
Propiedades de tipos
(C++11)
(C++11)
(C++14)
(C++11)(en desuso en C++26)
(C++11)(hasta C++20*)
(C++11)(en desuso en C++20)
(C++11)
Constantes de rasgos de tipo
Metafunciones
(C++17)
Operaciones admitidas
Relaciones y consultas de propiedades
Modificaciones de tipos
Transformaciones de tipos
(C++11)(en desuso en C++23)
(C++11)(en desuso en C++23)
(C++11)
(C++11)(hasta C++20*)(C++17)

Aritmética racional en tiempo de compilación
Secuencias de enteros en tiempo de compilación
 
Definido en el archivo de encabezado <type_traits>
template<class T >
struct is_function;
(desde C++11)

std::is_function es un UnaryTypeTrait.

Comprueba si T es un tipo función. Tipos como std::function, lambdas, clases con el operador operator() sobrecargado y punteros a funciones no cuentan como tipos función. Proporciona la constante miembro value, que es igual a true si T es un tipo función. De lo contrario, value es igual a false.

El comportamiento de un programa que añade especializaciones para is_functiono is_function_v(desde C++17) no está definido.

Contenido

[editar]Parámetros de plantilla

T - Un tipo a comprobar.

[editar]Plantilla de variable auxiliar

template<class T >
inlineconstexprbool is_function_v = is_function<T>::value;
(desde C++17)

Heredado de std::integral_constant

Constantes miembro

value
[estático]
true si T es un tipo función, de lo contrario false.
(constante miembro pública estática)

Funciones miembro

operator bool
Convierte el objeto a bool, devuelve value.
(función miembro pública)
operator()
(C++14)
Devuelve value.
(función miembro pública)

Tipos miembro

Tipo Definición
value_typebool
typestd::integral_constant<bool, value>

[editar]Notas

std::is_function puede implementarse de maneras mucho más simples. Las implementaciones similares a la siguiente se usan por nuevas versiones de libc++, libstdc++ y MS STL:

template<class T>struct is_function :std::integral_constant<bool, !std::is_const<const T>::value&&!std::is_reference<T>::value>{};

La implementación que se muestra debajo es para propósitos pedagógicos, ya que exhibe toda la gama de los distintos tipos de tipos función.

[editar]Posible implementación

// plantilla primariatemplate<class>struct is_function :std::false_type{};   // especialización para tipos regularestemplate<class Ret, class... Args>struct is_function<Ret(Args...)>:std::true_type{};   // especialización para funciones variádicas, tales como std::printftemplate<class Ret, class... Args>struct is_function<Ret(Args......)>:std::true_type{};   // especialización para tipos funci´øn que tienen calificadores-cvtemplate<class Ret, class... Args>struct is_function<Ret(Args...)const>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)volatile>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)constvolatile>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)const>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)volatile>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)constvolatile>:std::true_type{};   // especialización para tipos función que tienen calificadores de referenciatemplate<class Ret, class... Args>struct is_function<Ret(Args...)&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)const&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)volatile&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)constvolatile&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)const&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)volatile&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)constvolatile&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)&&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)const&&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)volatile&&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)constvolatile&&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)&&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)const&&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)volatile&&>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)constvolatile&&>:std::true_type{};   // especialización para las versiones noexcept de todas las dadas arriba// (C++17 y posterior)   template<class Ret, class... Args>struct is_function<Ret(Args...)noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)constnoexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)volatilenoexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)constvolatilenoexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)constnoexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)volatilenoexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)constvolatilenoexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)const&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)volatile&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)constvolatile&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)const&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)volatile&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)constvolatile&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)&&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)const&&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)volatile&&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args...)constvolatile&&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)&&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)const&&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)volatile&&noexcept>:std::true_type{};template<class Ret, class... Args>struct is_function<Ret(Args......)constvolatile&&noexcept>:std::true_type{};


[editar]Ejemplo

#include <iostream>#include <type_traits>   struct A {int fun()const&;};   template<typename>struct PM_traits {};   template<class T, class U>struct PM_traits<U T::*>{using member_type = U;};   int f();   int main(){std::cout<<std::boolalpha;std::cout<< std::is_function<A>::value<<'\n';std::cout<< std::is_function<int(int)>::value<<'\n';std::cout<< std::is_function<decltype(f)>::value<<'\n';std::cout<< std::is_function<int>::value<<'\n';   using T = PM_traits<decltype(&A::fun)>::member_type;// T es int() const&std::cout<< std::is_function<T>::value<<'\n';}

Salida:

false true true false true

[editar]Véase también

Comprueba si un tipo puede invocarse (como si lo fuera por std::invoke) con el número de argumentos dado.
(plantilla de clase)[editar]
(C++11)
Comprueba si un tipo es un tipo objeto
(plantilla de clase)[editar]
(C++11)
Comprueba si un tipo es un tipo clase (pero no un tipo unión).
(plantilla de clase)[editar]
close