存储在内存中的数值都有一个允许的数值范围。当计算结果超出了数值范围,就BOOM~~
#include <iostream>
using namespace std;
int main()
{
float x=2.5e30, y=1.0e30;
float z = x * y ;
// z应为2.5e60,然而这超出了范围
cout<<"z : "<<z<<endl;
// z为inf(无穷大)
cout<<"x : "<<x<<endl;
cout<<"x : "<<y<<endl;
// 这种错误称为overflow
cout << "~~~~~~~~~~~~~~~~~~~~~~" <<endl;
// 华丽的分割线
x=2.5e-30, y=1.0e30;
z = x / y;
// z的值应为2.5e-60,然而这和overflow的错误是类似的
cout<<"z : "<<z<<endl;
// 在我的系统中,发生指数下溢时,结果置为0
cout<<"x : "<<x<<endl;
cout<<"y : "<<y<<endl;
// 这种错误称为underflow
return 0;
}