std::as_const
Von cppreference.com
| Definiert in der Header-Datei <utility> |
||
| template< class T > constexpr std::add_const_t<T>& as_const( T& t ) noexcept; |
(1) | (seit C++17) |
| template< class T > void as_const( const T&& ) = delete; |
(2) | (seit C++17) |
1) Erzeugt einen lvalue-Referenz auf den const-Typ von t.
2) Die Überladung der const-rvalue-Referenz ist gelöscht, um rvalue-Argumente zu verhindern.
Inhalt |
[bearbeiten] Mögliche Implementierung
template<class T> constexpr std::add_const_t<T>& as_const(T& t) noexcept { return t; } |
[bearbeiten] Hinweise
| Feature-Test-Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_as_const |
201510L |
(C++17) | std::as_const
|
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <cassert> #include <string> #include <type_traits> #include <utility> int main() { std::string mutableString = "Hello World!"; auto&& constRef = std::as_const(mutableString); mutableString.clear(); // OK // constRef.clear(); // Error: 'constRef' is 'const' qualified, // but 'clear' is not marked const assert(&constRef == &mutableString); assert(&std::as_const(mutableString) == &mutableString); using ExprType = std::remove_reference_t<decltype(std::as_const(mutableString))>; static_assert(std::is_same_v<std::remove_const_t<ExprType>, std::string>, "ExprType should be some kind of string."); static_assert(!std::is_same_v<ExprType, std::string>, "ExprType shouldn't be a mutable string."); }
[bearbeiten] Siehe auch
| (C++11) |
prüft, ob ein Typ const-qualifiziert ist (Klassenvorlage) |
| (C++11)(C++11)(C++11) |
fügt const und/oder volatile Spezifizierer zum gegebenen Typ hinzu (Klassenvorlage) |
| (C++11)(C++11)(C++11) |
entfernt const und/oder volatile Spezifizierer vom gegebenen Typ (Klassenvorlage) |
konvertiert einen view in einen constant_range(Klassen-Template) (Range-Adaptor-Objekt) |