8

有时我得到一个 nan 作为乘法 no-nan b 和 c 的结果:

double a = b * c; //b = 0, c = 1024, a = nan

或作为 floor() 的结果:

double a = floor(b); //b = 2024, a = nan

sleep() 的重复计算和使用防止了这个问题:

a = b * c;  //a = nan
a = b * c;  //a = 0

a = floor(b);  //a = nan
a = floor(b);  //a = 2024

sleep(1);
a = b * c;  //a = 0

sleep(1);
a = floor(b);  //a = 2024

CPU是 AMD Athlon(tm) 64 X2 双核处理器 3400+

CPU温度

k8temp-pci-00c3
Adapter: PCI adapter
Core0 Temp: -1В°C
Core0 Temp: -2В°C
Core1 Temp: +3В°C
Core1 Temp: +7В°C

Adapter: SMBus PIIX4 adapter at 0b00
M/B Temp:    +30В°C  (low  =    +0В°C, high =   +85В°C)   
CPU Temp:  +28.5В°C  (low  =  +0.0В°C, high = +85.0В°C)   
M/B Crit:    +85В°C  (hyst =   +75В°C)                  
CPU Crit:   +124В°C  (hyst =  +114В°C)   

这个问题可能是 CPU 计时功能的结果吗?还是有其他问题的原因?

更新

我发现以下程序在该机器上产生 nan:

double a, b, c;
while(1) {
   a = 0;
   b = 1024;
   c = a * b; //c will be nan within 10-20 sec.
}
4

2 回答 2

5

您是否有可能在程序的其他地方发生堆栈或内存覆盖 - 线程处理错误或互斥锁处理错误?添加睡眠来“修复”问题让我认为这可能是一个并发问题。如果可能,调试这些值并查看它们是否从其他位置动态更改,并写入内存断点或者可能只是一些 printfs(这可能会改变问题的时间并隐藏它。)

于 2013-02-11T19:12:33.193 回答
1

实际上,这是特定于硬件的问题。当前平台上的以下程序工作 10-20 秒:

#include <math.h>
int main() {
   double a, b, c;
   while (1) {
      a = 0;
      b = 1024;
      c = a * b;
      if (isnan(c)) break;
   }
   return 0;
}
于 2013-02-16T20:03:05.163 回答