获得标准::复杂<double>通过标准::is_floating_point测试
Getting std::complex<double> to pass std::is_floating_point test
我希望类型double
, float
, complex<double>
和complex<float>
通过static_assert
条件。我认为static_assert(std::is_floating<T>::value, "some message")
可以做到这一点,但是复杂的类型不能通过这个测试(至少在gcc-4.10下)。
我应该添加什么谓词来确保这四种类型(可能还有long double
)被允许作为模板实例化,而不是其他类型?
为标准库类型trait类添加特化通常是非法的,即使对于用户定义的类型也是如此。§20.10.2 [meta.type.synop]/p1:
程序的行为,它为任何类型的对象添加专门化本款中定义的类模板是未定义的,除非另有说明。
目前,唯一允许用户添加专门化的类型trait类是std::common_type
,如果专门化中至少有一个模板参数是用户定义的类型(§20.10.7.6 [meta.trans.])。
你需要写你自己的trait,这并不难:
template<class T>
struct is_complex_or_floating_point : std::is_floating_point<T> { };
template<class T>
struct is_complex_or_floating_point<std::complex<T>> : std::is_floating_point<T> { };
演示。
如果你愿意使用Boost。类型特征,它们提供boost::is_complex
与std::complex
一起使用。
#include <complex>
#include <type_traits>
#include <boost/type_traits.hpp>
int main()
{
static_assert(std::is_floating_point<float>::value, "some message");
static_assert(std::is_floating_point<double>::value, "some message");
static_assert(boost::is_complex<std::complex<float>>::value, "some message");
static_assert(boost::is_complex<std::complex<double>>::value, "some message");
}
<<p> 生活例子/kbd> 相关文章:
- 使用CMake检测支持的C++标准
- 如何理解C++标准N3337中的expr.const.cast子句8
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- 编译标准库类型
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- Why is UINT32_MAX + 1 = 0?
- C++错误:"error: int aaa::bbb is protected within this context"
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 铸造标准::有没有回到原来的类型
- 创建具有 new in 函数和"this is nullptr"异常的对象
- 标准 N3337 5.2.10 第 7 条中的C++"类型"是什么意思?
- this_thread::sleep_for和计时时钟之间的关系是否由C++11标准指定
- 使用 cmake 的 Linux 终端上的"Conversion to non-scalar type is requested"错误
- 标准库类型的赋值运算符的引用限定符
- 标准是否严格定义了该程序应该如何编译?
- 如何从Windows应用程序输出到标准?
- 安全到标准:移动会员?
- 如何正确将字符串转换为标准::时间::system_clock::time_point?
- 这是否符合C++标准:双响双响,例如!!(-0.0).
- C++11标准是否保证"auto n2 = const_cast<int&>(n);" "n2 is int&"?