C语言fmax与max,c – max和fmax之间的差异(跨平台编译)

在Xcode中,编译很好:

float falloff = fmin(1.0, fmax(0.0, distanceSqrd/cRadius));

但是在Visual Studio 2010中它出错了,我必须使用max而不是fmax.

distanceSqrd和cRadius也都是浮点数.

这是我的代码中唯一没有无缝交叉编译的部分……

有什么想法吗?

解决方法:

来自< cmath>的函数std :: fmax和std :: fmin header(或来自< math.h>的fmax和fmin)是C 11特性以及Visual Studio 2010尚不支持的许多其他新数学函数(2012年也不支持).因此,为了便于携带,建议用< algorithm>中的std :: min和std :: max替换它们.

实际差异是,fmin和fmax是处理浮点数并且源自C99的数学函数(并且可能在可能的情况下通过实际的专用CPU指令实现),而min和max是可用于支持

对于特殊的浮点参数,它们的行为也略有不同.虽然没有完全指定min和max如何响应NaN,但我认为(尽管从上面的定义它们应该总是返回第一个操作数),fmin和fmax被明确指定为总是返回另一个(非NaN)参数时一个是NaN,如果实现符合IEEE 754(任何现代PC实现通常都是这样).

标签:c,xcode,visual-studio-2010

来源: https://codeday.me/bug/20191005/1857349.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值