std::is_empty
From cppreference.com
                    
                                        
                    
                    
                                                            
                    |   Defined in header <type_traits>
   | 
||
|   template< class T > struct is_empty;  | 
(since C++11) | |
If T is en empty type (that is, a non-union class type with no non-static members other than bit-fields of size 0, no virtual functions, no virtual base classes, and no non-empty base classes), provides the member constant value equal true. For any other type, value is false.
Contents | 
Inherited from std::integral_constant
Member constants
|    value [static]  | 
   true if  T is an empty class type , false otherwise   (public static member constant)  | 
Member functions
|    operator bool  | 
   converts the object to bool, returns value   (public member function)  | 
Member types
| Type | Definition | 
| value_type | bool | 
| type | std::integral_constant<bool, value> | 
[edit] Notes
sizeof(T) always returns 1 if T is empty, but inheriting from empty base classes usually does not increase the size of a class due to empty base optimization.
std::is_empty<T> and all other type traits are empty classes.
[edit] Example
#include <iostream> #include <type_traits> struct A {}; struct B { int m; }; struct C { virtual ~C(); }; int main() { std::cout << std::boolalpha; std::cout << std::is_empty<A>::value << '\n'; std::cout << std::is_empty<B>::value << '\n'; std::cout << std::is_empty<C>::value << '\n'; }
Output:
true false false
[edit] See also
|    (C++11)  | 
   checks if a type is a class type (but not union type)   (class template)  |