std::is_virtual_base_of
來自 cppreference.com
定義於標頭檔案 <type_traits> |
||
template< class Base, class Derived > struct is_virtual_base_of; |
(C++26 起) | |
std::is_virtual_base_of
是一個 BinaryTypeTrait。
如果 Base
是 Derived
的虛基類(忽略 cv-限定符),則提供成員常量 value 等於 true。否則 value 為 false。
如果 Base
和 Derived
都是非聯合類型別(忽略 cv-限定符),則 Derived
應該是一個完整型別;否則行為未定義。
如果程式為 std::is_virtual_base_of
或 std::is_virtual_base_of_v
新增特化,則行為未定義。
目錄 |
[編輯] 輔助變數模板
template< class Base, class Derived > constexpr bool is_virtual_base_of_v = is_virtual_base_of<Base, Derived>::value; |
(C++26 起) | |
繼承自 std::integral_constant
成員常量
value [靜態] |
如果 Derived 派生自虛基類 Base (忽略 cv-限定符),則為 true,否則為 false(public static 成員常量) |
成員函式
operator bool |
將物件轉換為 bool,返回 value (公開成員函式) |
operator() (C++14) |
返回 value (公開成員函式) |
成員型別
型別 | 定義 |
value_type
|
bool |
型別
|
std::integral_constant<bool, value> |
[編輯] 註解
std::is_virtual_base_of_v<A, B> 為 true,即使 A
是 B
的私有、保護或模糊基類。
如果 std::is_virtual_base_of_v<A, B> 為 true,則 std::is_base_of_v<A, B> 也為 true。然而,反過來不總是成立,因為對虛繼承的檢查更為具體。在這種情況下,std::is_virtual_base_of_v<T, T> 為 false,即使 T
是非聯合類型別。
[編輯] 示例
執行此程式碼
#include <type_traits> class A {}; class B : A {}; class C : B {}; class D : virtual A {}; class E : D {}; union F {}; using I = int; static_assert ( std::is_virtual_base_of_v<A, A> != true && std::is_virtual_base_of_v<A, B> != true && std::is_virtual_base_of_v<A, D> == true && std::is_virtual_base_of_v<D, E> != true && std::is_virtual_base_of_v<F, F> != true && std::is_virtual_base_of_v<I, I> != true ); int main() {}
[編輯] 參閱
(C++11) |
檢查一個型別是否為另一個型別的基類 (類模板) |
(C++11)(C++20) |
檢查一個型別是否可以轉換為另一個型別 (類模板) |
(C++20) |
指定型別派生自另一型別 (概念) |