std::as_const
來自 cppreference.com
在標頭檔案 <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 限定符 (類模板) |
(C++11)(C++11)(C++11) |
從給定型別中移除 const 和/或 volatile 限定符 (類模板) |
將 view 轉換為 constant_range (類模板) (範圍介面卡物件) |