加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

visual-c-std :: isfinite在MSVC上

发布时间:2020-12-16 05:31:16 所属栏目:百科 来源:网络整理
导读: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编译器来
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和浮点异常的复杂性).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读