std::has_virtual_destructor

来自cppreference.com
< cpp‎ | types
 
 
元编程库
类型特性
类型类别
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
类型属性
(C++11)
(C++11)
(C++14)
(C++11)
(C++11)(C++20 前)
(C++11)(C++20 中弃用)
(C++11)
类型特性常量
元函数
(C++17)
受支持操作
关系与属性查询
类型修改
(C++11)(C++11)(C++11)
类型变换
(C++11)
(C++11)
(C++17)
(C++11)(C++20 前)(C++17)
编译时有理数算术
编译时整数序列
 
在标头 <type_traits> 定义
template< class T >
struct has_virtual_destructor;
(C++11 起)

std::has_virtual_destructor一元类型特性 (UnaryTypeTrait)

如果 T 是拥有虚析构函数的类型,那么成员常量 value 等于 true。对于其它类型,value 等于 false

如果 T 是不完整的非联合类类型,那么行为未定义。

添加 std::has_virtual_destructorstd::has_virtual_destructor_v 的特化的程序行为未定义。

模板形参

T - 要检查的类型

辅助变量模板

template< class T >
inline constexpr bool has_virtual_destructor_v = has_virtual_destructor<T>::value;
(C++17 起)

继承自 std::integral_constant

成员常量

value
[静态]
如果  T 拥有虚析构函数那么是 true,否则是 false
(公开静态成员常量)

成员函数

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

成员类型

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

注解

如果类拥有公开虚析构函数,那么可以从它派生,且可以通过指向基类的指针安全地删除派生类( GotW #18)。此时 std::is_polymorphic<C>::value 等于 true

示例

#include <type_traits>
 
struct S {};
static_assert(!std::has_virtual_destructor_v<S>);
 
struct B { virtual ~B() {} };
static_assert(std::has_virtual_destructor_v<B>);
 
struct D : B { ~D() {} };
static_assert(std::has_virtual_destructor_v<D>);
 
int main()
{
    B* pd = new D;
    delete pd;
}

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 2015 C++11 T 是不完整的联合体类型时行为未定义 此时 value 等于 true

参阅

检查类型是否拥有未被弃置的析构函数
(类模板)
检查类型是否为多态类类型
(类模板)