NaN何时不在C中传播?

NaN通过“大多数”操作传播,如 NaN – Wikipedia中所述.

我想知道NaN不传播的操作.例如,我在C编码,发现以下代码打印1,这不是NaN.

const double result = std::pow(1,std::numeric_limits<double>::quiet_NaN());
std::cout << result << std::endl;

对于std :: powfunction,此行为在std::pow – cppreference.com中描述.

你能分享一下其他的例子吗?

解决方法

std :: pow实际上并不是一个运算符,因为a * b中的乘法就像是一个操作.这是一个功能.函数可以有分支,可以随意处理NaN.在某种意义上,另一个类似的std函数是std :: is_nan.这也不会传播NaN:它返回一个可以隐式转换为数字类型的bool:
std::is_nan(std::is_nan(a))

对于允许表达式编译的任何类型,它都是false.其他示例包括std :: fpclassify和std :: isfinite.我特别喜欢std :: fpclassify作为一个例子,因为它有一个int返回类型,所以它真的是一个数字函数而不是pow!

请注意,根据this question的接受答案,将NaN隐式转换为bool定义为false true,这很重要.它允许!,&&和||与NaN合作.最后,表达式分隔符运算符也不传播NaN,并且忽略三元条件运算的未使用分支上的NaN.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...