函数名:_control87

头文件:<float.h>

函数原型:  unsigned int _control87(unsigned int new,unsigned int mask);

功能: 获取和设置浮点控制字

参数:   unsigned int new   新的控制字位值 , unsigned int mask  设置新控制字位的掩码

返回值:返回浮点控制字


程序例: 实现在不同控制字下计算两个双精度的乘积

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include<stdio.h>
 
#include<float.h>
 
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;  
 
}

  

运行结果:

1
2
3
4
original: 0x8001f
0.1*0.1=1.000000000000000e-002
24-bit:0xa001f
0.1*0.1=9.999999776482582e-003


点赞(85)

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

Dotcpp在线编译      (登录可减少运行等待时间)
#include<stdio.h>
int main()
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX