Namensräume
Varianten
Aktionen

std::as_const

Von cppreference.com
< cpp‎ | utility
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
Ganzzahl-Vergleichsfunktionen
(C++20)(C++20)(C++20)  
(C++20)
Swap und Typ-Operationen
(C++14)
(C++11)
(C++11)
(C++11)
as_const
(C++17)
Gemeinsame Vokabulartypen
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)



 
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

#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) [bearbeiten]
(C++11)(C++11)(C++11)
fügt const und/oder volatile Spezifizierer zum gegebenen Typ hinzu
(Klassenvorlage) [bearbeiten]
entfernt const und/oder volatile Spezifizierer vom gegebenen Typ
(Klassenvorlage) [bearbeiten]
konvertiert einen view in einen constant_range
(Klassen-Template) (Range-Adaptor-Objekt)[edit]