std::is_scalar
来自cppreference.com
在标头 <type_traits> 定义 | ||
template<class T > struct is_scalar; | (C++11 起) | |
std::is_scalar
是一元类型特征(UnaryTypeTrait) 。
如果 T
是标量类型,那么提供的成员常量 value
等于 true。对于其它任何类型,value
等于 false。
如果程序添加了 std::is_scalar
或 std::is_scalar_v
的特化,那么行为未定义。
目录 |
[编辑]模板形参
T | - | 要检查的类型 |
[编辑]辅助变量模板
template<class T > constexprbool is_scalar_v = is_scalar<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> |
[编辑]注解
C++ 内存模型中的每个独立内存位置,包括语言特性所用的隐藏内存位置(如虚表指针),都拥有标量类型(或为相邻的非零长位域序列)。表达式求值中的副作用顺序、线程间同步和依赖顺序全部都基于标量对象定义。
[编辑]可能的实现
template<class T>struct is_scalar :std::integral_constant<bool, std::is_arithmetic<T>::value||std::is_enum<T>::value||std::is_pointer<T>::value||std::is_member_pointer<T>::value||std::is_null_pointer<T>::value>{}; |
[编辑]示例
运行此代码
#include <iostream>#include <type_traits>#include <typeinfo>#include <utility> template<typename Head, typename... Tail>void are_scalars(Head&& head, Tail&&... tail){using T =std::decay_t<decltype(head)>; std::cout<<typeid(T).name()<<" "<<(std::is_scalar_v<T>?"":"不")<<"是标量类型\n"; ifconstexpr(sizeof... (Tail)){ are_scalars(std::forward<decltype(tail)>(tail)...);}} int main(){struct S {int m;} s;int S::* mp =&S::m;enumclass E { e }; are_scalars(42, 3.14, E::e, "str", mp, nullptr, s);}
可能的输出:
int 是标量类型 double 是标量类型 main::E 是标量类型 char const* 是标量类型 int main::S::* 是标量类型 nullptr 是标量类型 main::S 不是标量类型
[编辑]参阅
(C++11) | 检查类型是否为算术类型 (类模板) |
(C++11) | 检查类型是否为枚举类型 (类模板) |
(C++11) | 检查类型是否为指针类型 (类模板) |
(C++11) | 检查类型是否为指向非静态成员函数或对象的指针类型 (类模板) |