函数名:_control87
头文件:
函数原型: unsigned int _control87(unsigned int new,unsigned int mask);
功能: 获取和设置浮点控制字
参数: unsigned int new 新的控制字位值 , unsigned int mask 设置新控制字位的掩码
返回值:返回浮点控制字
程序例: 实现在不同控制字下计算两个双精度的乘积#include
#include
int main(){
double a=0.1;
printf("original: 0x%4x\n", _control87(0,0)); //输出原来的控制字
printf("%1.1f*%1.1f=%.15e\n",a,a,a*a); // 计算两个双精度的乘积
//输出24位字长的控制字
printf("24-bit:0x%4x\n",_control87(_PC_24,_MCW_PC));
printf("%1.1f*%1.1f=%.15e\n",a,a,a*a); // 计算两个双精度的乘积
return 0;
}
运行结果:original: 0x8001f
0.1*0.1=1.000000000000000e-002
24-bit:0xa001f
0.1*0.1=9.999999776482582e-003