名稱空間
變體
操作

std::as_const

來自 cppreference.com
< cpp‎ | 工具
 
 
 
在標頭檔案 <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)t 的型別形成 const 的左值引用。
2) const 右值引用過載被刪除,以禁止右值引數。

目錄

[編輯] 可能實現

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 = "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.");
}

[編輯] 參閱

(C++11)
檢查型別是否為 const 限定
(類模板) [編輯]
(C++11)(C++11)(C++11)
向給定型別新增 const 和/或 volatile 限定符
(類模板) [編輯]
從給定型別中移除 const 和/或 volatile 限定符
(類模板) [編輯]
view 轉換為 constant_range
(類模板) (範圍介面卡物件)[編輯]