visual-c-std :: isfinite在MSVC上

前端之家收集整理的这篇文章主要介绍了visual-c-std :: isfinite在MSVC上前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
C 11和C 11标准定义了
std::isfinite
功能. Visual Studio 2012似乎并没有提供它作为的一部分
cmath或math.h,但是有amp_math.h
seems to provide this function.

isd是否与std :: isfinite可互换?该
文档并不涉及使用NAN调用时的行为
我没有一个VS编译器来测试这个.

解决方法

正如Marius已经指出的那样,来自amp_math.h的isfinite将用于C AMP,它是与CUDA或OpenCL类似的多核架构上的并行计算的MS扩展.而且由于此功能只能用于实际的AMP限制功能(通常是GPU内核),因此对您而言并不常用.

不幸VS 2012不支持C11数学和浮点控制功能.但是,一旦你认识到你在VC上实现了特殊的代码,你可以使用< float.h>中的_finite(或者更确切地说,_finite),这是至少VS 2003所支持的MS-secific功能.但是请记住,_finite只需要双倍,因此转换任何非双参数(尽管VC似乎没有适当的长双重),其所有的含义(而INF和安静的NaN应该被转换没有问题,m不知道在转换中的信号NaN上的陷阱是否也是直接调用std ::有限的).

VC的标准库有other such functions,因为缺乏C11 / C99支持(如_isnan等). (为什么他们拒绝在这些功能前面删除那个下划线,并在_controlfp周围放置一个简单的< cfenv>包装器,从而更接近完成C 11的支持是一个完全不同的问题.)

编辑:除此之外,检查INF和NaNs的直接方法也可能会起作用:

template<typename T> bool isfinite(T arg)
{
    return arg == arg && 
           arg != std::numeric_limits<T>::infinity() &&
           arg != -std::numeric_limits<T>::infinity();
}

但是,当然也有可能陷入信号NaN的同样的暗示(尽管我不得不承认,我不太熟悉信号NaNs和浮点异常的复杂性).

猜你在找的C&C++相关文章