Namespaces
Variants

std:: is_const

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
is_const
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
定义于头文件 <type_traits>
template < class T >
struct is_const ;
(C++11 起)

std::is_const 是一个 UnaryTypeTrait

如果 T 是 const 限定类型(即 const ,或 const volatile ),则提供等于 true 的成员常量 value 。对于任何其他类型, value false

如果程序为 std::is_const std::is_const_v 添加特化,则行为是未定义的。

目录

模板参数

T - 待检查的类型

辅助变量模板

template < class T >
constexpr bool is_const_v = is_const < T > :: value ;
(C++17 起)

继承自 std:: integral_constant

成员常量

value
[static]
T 为 const 限定类型则为 true ,否则为 false
(公开静态成员常量)

成员函数

operator bool
转换对象为 bool 类型,返回 value
(公开成员函数)
operator()
(C++14)
返回 value
(公开成员函数)

成员类型

类型 定义
value_type bool
type std:: integral_constant < bool , value >

注释

如果 T 是引用类型,那么 is_const < T > :: value 始终为 false 。检查可能为引用类型的常量正确性的正确方式是移除引用: is_const < typename remove_reference < T > :: type >

可能的实现

template<class T> struct is_const          : std::false_type {};
template<class T> struct is_const<const T> : std::true_type {};

示例

#include <type_traits>
static_assert(std::is_same_v<const int*, int const*>,
    "请记住,常量性在指针内部紧密绑定。");
static_assert(!std::is_const_v<int>);
static_assert(std::is_const_v<const int>);
static_assert(!std::is_const_v<int*>);
static_assert(std::is_const_v<int* const>,
    "因为指针本身不可更改,但指向的整型值可以更改。");
static_assert(!std::is_const_v<const int*>,
    "因为指针本身可以更改,但指向的整型值不可更改。");
static_assert(!std::is_const_v<const int&>);
static_assert(std::is_const_v<std::remove_reference_t<const int&>>);
struct S
{
    void foo() const {}
    void bar() const {}
};
int main()
{
    // 常量成员函数的常量性表现方式不同:
    static_assert(!std::is_const_v<decltype(&S::foo)>,
        "因为 &S::foo 是一个指针。");
    using S_mem_fun_ptr = void(S::*)() const;
    S_mem_fun_ptr sfp = &S::foo;
    sfp = &S::bar; // 正常,可以重新指向
    static_assert(!std::is_const_v<decltype(sfp)>,
        "因为 sfp 是相同的指针类型,因此可以重新指向。");
    const S_mem_fun_ptr csfp = &S::foo;
    // csfp = &S::bar; // 错误
    static_assert(std::is_const_v<decltype(csfp)>,
        "因为 csfp 不能重新指向。");
}

参见

检查类型是否具有 volatile 限定符
(类模板)
(C++17)
获取指向其参数的 const 引用
(函数模板)