std::as_const
De cppreference.com
<tbody>
</tbody>
| 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.Posible implementación
template <typename T>
constexpr std::add_const_t<T>& as_const(T& t) noexcept
{
return t;
}
|
Notas
| Macro de Prueba de característica | Valor | Estándar | Comentario |
|---|---|---|---|
__cpp_lib_as_const |
201510L |
(C++17) | std::as_const
|
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." );
}
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) |