Пространства имён
Варианты
Действия

std::as_const

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
<tbody> </tbody>
Определено в заголовочном файле <utility>
template< class T > constexpr std::add_const_t<T>& as_const( T& t ) noexcept;
(1) (начиная с C++17)
template< class T > void as_const( const T&& ) = delete;
(2) (начиная с C++17)
1) Формирует ссылку lvalue на константный тип t.
2) Перегрузка ссылки const rvalue удалена, чтобы запретить аргументы rvalue.

Возможная реализация

template <class T>
constexpr std::add_const_t<T>& as_const(T& t) noexcept
{
    return t;
}

Примечание

Макрос Тестирования функциональности Значение Стандарт Функциональность
__cpp_lib_as_const 201510L (C++17) std::as_const

Пример

#include <cassert>
#include <string>
#include <type_traits>
#include <utility>

int main()
{
    std::string mutableString = "Привет Мир!";
    auto&& constRef = std::as_const(mutableString);

    mutableString.clear(); // OK
//  constRef.clear(); // Ошибка: 'constRef' имеет квалификацию 'const',
                      //         а 'clear' не помечена как 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 должен быть какой нибудь строкой" );
    static_assert(!std::is_same_v<ExprType, std::string>,
                  "не должен быть mutable строкой." );
}

Смотрите также

(C++11)
проверяет, является ли тип квалифицированным как const
(шаблон класса) [править]
(C++11)(C++11)(C++11)
добавляет спецификаторы const и/или volatile к данному типу
(шаблон класса) [править]
удаляет спецификаторы const и/или volatile из данного типа
(шаблон класса) [править]
преобразует view в constant_range
(шаблон класса) (объект адаптера диапазона) [править]