整型的 std::isnan 和 std::isinf 的重载
Overloads of std::isnan and std::isinf for integral types
Cpp首选项提到了整型的std::isnan
和std::isinf
(也许还有其他(的重载。这使得以下调用明确:
std::isnan(1);
但是,我在C++标准中找不到任何此类重载。我检查了 C++11 和当前草稿,只有 float
、double
和 long double
的重载。
至于编译器行为,GCC 和 Clang 都编译代码,但 MSVC 不编译。谁是对的?cpp首选项的整体重载从何而来?
cmath 标准页面末尾有一段:
积分重载对于
2. 否则,如果任何对应于双精度参数的算术类型的参数具有双精度<cmath>
内的每一组重载函数,除了abs
,应该有额外的重载足以确保:或整数类型,则所有对应于双精度参数的算术类型的参数都将有效地转换为双精度。
是必需的,否则会在三个浮点重载之间收到不明确的调用,但未指定如何实现此类重载。
请注意,<cmath>
标头中的其他函数对整型类型具有正确的重载,例如,
std::atan(1)
调用模板化版本 double atan<int,void>(int)
。
这是一个概要,有一个脚注
对于 中的每组重载函数,除了 abs 之外,应该有额外的重载足以确保:
。
否则,如果对应于双精度参数的任何算术类型的参数具有双精度
- 或整数类型,则对应于双精度参数的所有算术类型的参数都将有效地转换为双精度。
对应于bool isnan( IntegralType arg )
描述
一组重载或接受任何整型 arg 参数的函数模板。等效于 (2((参数转换为双精度(。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 如何从 std::atomic 中提取指针 T<T>?
- 整型的 std::isnan 和 std::isinf 的重载
- val != std::numeric_limits:<double>:infinity() 或 !isinf(val) 或 isfinite(val)
- std::isinf不适用于-fast数学.如何检查无穷大