std::as_const
De cppreference.com
Definido en el archivo de encabezado <utility>
|
||
template <typename T> constexpr std::add_const_t<T>& as_const(T& t) noexcept; |
(1) | (desde C++17) |
template <typename T> void as_const(const T&&) = delete; |
(2) | (desde C++17) |
1) Forma una referencia l-valor al tipo
const
de t
.2) La sobrecarga de la referencia
const
r-valor se elimina para rechazar argumentos r-valor.Contenido |
[editar] Posible implementación
template <typename T> constexpr std::add_const_t<T>& as_const(T& t) noexcept { return t; } |
[editar] Notas
Macro de Prueba de característica | Valor | Estándar | Comentario |
---|---|---|---|
__cpp_lib_as_const |
201510L | (C++17) | std::as_const
|
[editar] Ejemplo
Ejecuta este código
#include <string> #include <cassert> #include <utility> #include <type_traits> int main() { std::string cadenaMutable = "Hola mundo!"; const std::string& vistaConstante = std::as_const(cadenaMutable); assert( &vistaConstante == &cadenaMutable ); assert( &std::as_const( cadenaMutable ) == &cadenaMutable ); using QueTipoEs = std::remove_reference_t<decltype(std::as_const(cadenaMutable))>; static_assert(std::is_same<std::remove_const_t<QueTipoEs>, std::string>::value, "QueTipoEs debe ser algun tipo de cadena." ); static_assert(!std::is_same< QueTipoEs, std::string >::value, "QueTipoEs no debe ser una cadena mutable." ); }
[editar] Véase también
(C++11) |
Comprueba si un tipo está calificado con el calificador const (plantilla de clase) |
(C++11)(C++11)(C++11) |
Agrega los especificadores const y/o volatile al tipo dado (plantilla de clase) |
(C++11)(C++11)(C++11) |
Elimina los especificadores const y/o volatile del tipo dado. (plantilla de clase) |
Convierte una vista (view ) en un rango constante (constant_range ). (plantilla de clase) (objeto adaptador de rango) |